{"id":1438,"date":"2018-10-25T21:52:44","date_gmt":"2018-10-25T12:52:44","guid":{"rendered":"https:\/\/www.rocher.kyoto.jp\/arbr\/?p=1438"},"modified":"2018-10-25T21:52:44","modified_gmt":"2018-10-25T12:52:44","slug":"jenkins-pipeline%e5%86%85%e3%81%aepostgres%e3%81%ab%e3%81%a6db%e3%83%80%e3%83%b3%e3%83%97%e5%8f%96%e5%be%97","status":"publish","type":"post","link":"https:\/\/www.rocher.kyoto.jp\/arbr\/?p=1438","title":{"rendered":"jenkins pipeline\u5185\u306epostgres\u306b\u3066DB\u30c0\u30f3\u30d7\u53d6\u5f97"},"content":{"rendered":"<h1>\u74b0\u5883<\/h1>\n<p>CentOS Linux release 7.5.1804 (Core) Docker\u306eHost\u30de\u30b7\u30f3<br \/>\nJenkins 2.138.1<br \/>\nDocker Commons Plugin<br \/>\nDocker Pipeline<br \/>\npostgres 11(\u516c\u5f0f\u306edocker-image latest)<\/p>\n<h1>\u3084\u308a\u305f\u304b\u3063\u305f\u3053\u3068<\/h1>\n<p>\u4ed6\u306eDB\u30b5\u30fc\u30d0\u304b\u3089\u30c7\u30fc\u30bf\u3092\u6301\u3063\u3066\u6765\u3066\u30c0\u30f3\u30d7\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u308a\u305f\u304b\u3063\u305f\u3002<\/p>\n<h1>\u52d5\u3044\u305fJenkinsfile\u8a2d\u5b9a<\/h1>\n<p>.pgpass\u3092\u4efb\u610f\u306e\u30d1\u30b9\uff08\u3053\u3053\u3067\u306fhost\u306e\/ci\/app\/hoge\uff09\u306b\u7f6e\u304d\u3001\u305d\u306e\u30d1\u30b9\u3092v\u30aa\u30d7\u30b7\u30e7\u30f3\u3067\u30de\u30a6\u30f3\u30c8\u3001\u3055\u3089\u306b\u30de\u30a6\u30f3\u30c8\u3057\u305f\u30d5\u30a1\u30a4\u30eb(\u3053\u3053\u3067\u306f\/root\/.pgpass)\u3092e\u30aa\u30d7\u30b7\u30e7\u30f3\u3067\u6307\u5b9a\u3002<\/p>\n<pre>    \r\npipeline {\r\n  agent none\r\n  stages{\r\n    stage('DB\u30b3\u30d4\u30fc\u30d5\u30a7\u30fc\u30ba') {\r\n      agent {\r\n        docker {\r\n          image 'postgres'\r\n          args '-v \/ci\/app\/hoge:\/root -e PGPASSFILE=\/root\/.pgpass'\r\n        }\r\n      }\r\n  \r\n      steps {\r\n        sh 'pg_dump -h \u30db\u30b9\u30c8\u540d -p 5432 -U \u30e6\u30fc\u30b6\u540d DB\u540d &gt; \/root\/test.sql'\r\n        sh 'echo DB\u30b3\u30d4\u30fc'\r\n      }\r\n    }\r\n  }\r\n}\r\n<\/pre>\n<h1>\u52d5\u304b\u306a\u304b\u3063\u305f\u8a2d\u5b9a<\/h1>\n<p>.pgpass\u3092\u4efb\u610f\u306e\u30d1\u30b9\uff08\u3053\u3053\u3067\u306fhost\u306e\/ci\/app\/hoge\uff09\u306b\u7f6e\u304d\u3001\u305d\u306e\u30d1\u30b9\u3092\u30db\u30fc\u30e0\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3068\u3057\u3066\u74b0\u5883\u5909\u6570\u3067\u6307\u5b9a\u3002<\/p>\n<pre>\r\nargs '-v \/ci\/app\/hoge:\/home\/ciuser -e HOME=\/home\/ciuser'\r\n<\/pre>\n<p>postgres\u30b3\u30f3\u30c6\u30ca\u5185\u306e\u74b0\u5883\u5909\u6570\u306b\u306fHOME\u304c\u53cd\u6620\u3055\u308c\u3066\u3044\u308b\u304c.pgpass\u306f\u8aad\u307f\u8fbc\u307e\u308c\u306a\u304b\u3063\u305f\u3002<br \/>\n\u591a\u5206<br \/>\ngetpwuid\u3067\u5b9f\u884c\u30e6\u30fc\u30b6(uid1000)\u3067\u74b0\u5883\u5909\u6570\u3067\u306f\u306a\u304f\/etc\/passwd\u304b\u3089\u30db\u30fc\u30e0\u3092\u53d6\u5f97\u3057\u3088\u3046\u3068\u3059\u308b<br \/>\npostgres\u30b3\u30f3\u30c6\u30ca\u306b\u306fuid1000\u306e\u30e6\u30fc\u30b6\u306f\u3044\u306a\u3044\u304b\u3089\u30db\u30fc\u30e0\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u304c\u53d6\u5f97\u3067\u304d\u306a\u3044\uff08echo\u3057\u3066\u307f\u305f\u3089\/\u3067\u8868\u793a\u3055\u308c\u3066\u306f\u3044\u305f\uff09<br \/>\n\/\u306b\u306f.pgpass\u304c\u7121\u3044\u304b\u3089\u30a8\u30e9\u30fc<br \/>\n\u3068\u3044\u3046\u6d41\u308c\u3068\u601d\u3046\u304c\u8abf\u67fb\u306f\u9014\u4e2d\u3067\u3084\u3081\u305f\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u74b0\u5883 CentOS Linux release 7.5.1804 (Core) Docker\u306eHost\u30de\u30b7\u30f3 Jenkins 2.138.1 Docker Commons Plugin Docker Pipeline p [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[96,108],"tags":[92,112,87],"class_list":["post-1438","post","type-post","status-publish","format-standard","hentry","category-docker","category-jenkins","tag-docker","tag-jenkins","tag-postgres"],"_links":{"self":[{"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/posts\/1438","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1438"}],"version-history":[{"count":1,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/posts\/1438\/revisions"}],"predecessor-version":[{"id":1439,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=\/wp\/v2\/posts\/1438\/revisions\/1439"}],"wp:attachment":[{"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1438"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1438"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.rocher.kyoto.jp\/arbr\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1438"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}