{"id":259,"date":"2023-10-19T07:01:00","date_gmt":"2023-10-18T22:01:00","guid":{"rendered":"https:\/\/portal-sight.com\/wp1\/?p=259"},"modified":"2023-10-19T03:33:52","modified_gmt":"2023-10-18T18:33:52","slug":"fly-io%e3%81%a7%e8%8b%a6%e5%8a%b4%e3%81%97%e3%81%9f%e8%a9%b1","status":"publish","type":"post","link":"https:\/\/portal-sight.com\/wp1\/?p=259","title":{"rendered":"fly.io\u3067\u82e6\u52b4\u3057\u305f\u8a71"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\">Heroku\u306e\u7121\u6599\u67a0\u304c\u306a\u304f\u306a\u3063\u3066\u4e00\u5e74\u3050\u3089\u3044\u306b\u306a\u308a\u307e\u3059\u304c\u3001\u81ea\u5206\u7528\u306e\u30b5\u30fc\u30d3\u30b9\uff08python\u306epyramid\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3092\u4f7f\u3063\u3066\u5927\u6614\u306b\u4f5c\u3063\u305f\u3082\u306e\uff09\u3092\u3068\u308a\u3042\u3048\u305arender\u306b\u79fb\u3057\u305f\u3042\u3068\u653e\u7f6e\u3057\u3066\u305f\u3082\u306e\u3092\u3001\u518d\u5ea6fly.io\u3067\u52d5\u304f\u3088\u3046\u306b\u3057\u305f\u3068\u304d\u306e\u4e8b<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">fly.io \u3078\u306e\u767b\u9332\u304b\u3089flyctl launch \u307e\u3067\u306f\u9806\u8abf\u306b\uff08https:\/\/zenn.dev\/hokawa\/articles\/65ddcd9974448c \u3092\u53c2\u8003\u306b\uff09\u3002\u30ed\u30fc\u30ab\u30eb\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u3067\u304d\u305fProcfile\u306fheroku\u306b\u4f7f\u3063\u305f\u3082\u306e\u3092\u305d\u306e\u307e\u307e\u3002flyctl deploy\u3063\u3066git\u306b\u95a2\u4fc2\u306a\u304f\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3059\u308b\u3093\u3067\u3059\u306d\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">deploy\u3067\u30d5\u30a1\u30a4\u30eb\u306e\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u5f8c\u306b\u6ce3\u304b\u3055\u308c\u305f\u306e\u306f<\/p>\n\n\n\n<blockquote class=\"wp-block-quote is-layout-flow wp-block-quote-is-layout-flow\">\n<p class=\"wp-block-paragraph\">sqlalchemy.exc.NoSuchModuleError: Can&#8217;t load plugin: sqlalchemy.dialects:postgres\u304c\u51fa\u308b<\/p>\n<cite>https:\/\/zenn.dev\/3w36zj6\/scraps\/ebb3a8bf494aa4<\/cite><\/blockquote>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u306e\u5185\u5bb9\u3092\u53cd\u6620\u3055\u305b\u308b\u305f\u3081\u306b\u3001\u30a2\u30d7\u30ea\u306e\u6700\u521d\u306e\u65b9\u3067<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>os.environ&#91;'DATABASE_URL'] = os.environ&#91;\"DATABASE_URL\"].replace(\"postgres:\/\/\", \"postgresql:\/\/\")<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3092\u633f\u5165<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u3082\u3046\u4e00\u70b9\u3001postgresql\u306e\u30c6\u30fc\u30d6\u30eb\u4f5c\u6210\u3068\u30c7\u30fc\u30bf\u633f\u5165\u3092\u30b3\u30fc\u30c9\u304b\u3089\u3067\u306f\u306a\u304f\u3001fly postgres connect -a &lt;postgresql\u30a2\u30d7\u30ea\u540d>\u3067\u63a5\u7d9a\u3057\u3066SQL\u3092\u6d41\u3057\u8fbc\u3093\u3067\u884c\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u305d\u306e\u30c6\u30fc\u30d6\u30eb\u304c\u898b\u3064\u304b\u308a\u307e\u305b\u3093\uff08relation does not exist\uff09\u30a8\u30e9\u30fc<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"http:\/\/\u3010PostgreSQL\u3011\u30c6\u30fc\u30d6\u30eb\u304c\u5b58\u5728\u3059\u308b\u306e\u306b\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u5b58\u5728\u3057\u307e\u305b\u3093(relation does not exist)\u3068\u8868\u793a\u3055\u308c\u308b - buralog https:\/\/buralog.jp\/postgresql-relation-does-not-exist-error\/\">http:\/\/\u3010PostgreSQL\u3011\u30c6\u30fc\u30d6\u30eb\u304c\u5b58\u5728\u3059\u308b\u306e\u306b\u30ea\u30ec\u30fc\u30b7\u30e7\u30f3\u5b58\u5728\u3057\u307e\u305b\u3093(relation does not exist)\u3068\u8868\u793a\u3055\u308c\u308b &#8211; buralog https:\/\/buralog.jp\/postgresql-relation-does-not-exist-error\/<\/a><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u306b\u66f8\u304b\u308c\u3066\u308b\u3001\u5927\u6587\u5b57\u5c0f\u6587\u5b57\u3084\u30b5\u30fc\u30c1\u30d1\u30b9\u306f\u554f\u984c\u306a\u304b\u3063\u305f\u306e\u3067\u3059\u304c\u3001<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"http:\/\/fly.io postgres: relation &quot;table_name&quot; does not exist. \u306e\u89e3\u6c7a https:\/\/zenn.dev\/yutorse\/articles\/0a7dfcef4b0d05\">fly.io postgres: relation &#8220;table_name&#8221; does not exist. \u306e\u89e3\u6c7a<br>https:\/\/zenn.dev\/yutorse\/articles\/0a7dfcef4b0d05<\/a><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u306e\u5225\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u30c6\u30fc\u30d6\u30eb\u3092\u767b\u9332\u3057\u3066\u3057\u307e\u3063\u3066\u3044\u308b\u3002\u304c\u8a72\u5f53\u3057\u305f\u306e\u3067\u3001\u3053\u3061\u3089\u306e\u30b5\u30a4\u30c8\u306b\u306fflyctl proxy~\u306a\u308b\u30b3\u30de\u30f3\u30c9\u304c\u66f8\u304b\u308c\u3066\u307e\u3059\u304c\u3001\u3053\u3053\u306f\u3046\u307e\u304f\u3044\u304b\u306a\u304b\u3063\u305f\u305f\u3081\u3001\u666e\u901a\u306bfly postgres connect\u3057\u305f\u3042\u3068\u3067psql\u306e\u30b3\u30de\u30f3\u30c9\\c \u3092\u4f7f\u3063\u3066\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u5207\u308a\u66ff\u3048\u305f\u3042\u3068\u3067\u518d\u5ea6SQL\u3092\u6d41\u3057\u305f\u3068\u3053\u308d\u3001\u3046\u307e\u304f\u52d5\u304d\u51fa\u3057\u307e\u3057\u305f<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u3042\u3001\u3042\u3068\u306frequirement.txt\u3067psycopg2\u304c\u3046\u307e\u304f\u5165\u308c\u3089\u308c\u306a\u304b\u3063\u305f\u306e\u3067psycopg2-binary\u306b\u5909\u66f4\u3057\u305f\u3088\u3046\u306a\u6c17\u304c\u3057\u307e\u3059<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Heroku\u306e\u7121\u6599\u67a0\u304c\u306a\u304f\u306a\u3063\u3066\u4e00\u5e74\u3050\u3089\u3044\u306b\u306a\u308a\u307e\u3059\u304c\u3001\u81ea\u5206\u7528\u306e\u30b5\u30fc\u30d3\u30b9\uff08python\u306epyramid\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3092\u4f7f\u3063\u3066\u5927\u6614\u306b\u4f5c\u3063\u305f\u3082\u306e\uff09\u3092\u3068\u308a\u3042\u3048\u305arender\u306b\u79fb\u3057\u305f\u3042\u3068\u653e\u7f6e\u3057\u3066\u305f\u3082\u306e\u3092\u3001\u518d\u5ea6fly.io\u3067\u52d5\u304f\u3088 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_crdt_document":"","footnotes":""},"categories":[1],"tags":[],"class_list":["post-259","post","type-post","status-publish","format-standard","hentry","category-1"],"_links":{"self":[{"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/posts\/259","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=259"}],"version-history":[{"count":1,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/posts\/259\/revisions"}],"predecessor-version":[{"id":260,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=\/wp\/v2\/posts\/259\/revisions\/260"}],"wp:attachment":[{"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=259"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=259"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/portal-sight.com\/wp1\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=259"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}