{"id":41954,"date":"2023-06-18T07:41:17","date_gmt":"2024-03-04T12:50:57","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/"},"modified":"2024-04-30T09:26:09","modified_gmt":"2024-04-30T01:26:09","slug":"%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/","title":{"rendered":"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf"},"content":{"rendered":"<p>\u8fd9\u662f\u5728CentOS7\/8\u4e0a\u521b\u5efaPostgreSQL12\u7684Docker\u955c\u50cf\u7684\u6b65\u9aa4\u8bb0\u5f55\u3002(\u7531\u4e8e\u5c1d\u8bd5\u521b\u5efaDocker\u955c\u50cf\u65f6\u9047\u5230\u4e86\u6bd4\u9884\u671f\u66f4\u591a\u7684\u56f0\u96be\u548c\u8bd5\u9519\uff0c\u6240\u4ee5\u6211\u5c06\u5176\u4f5c\u4e3a\u5907\u5fd8\u5f55\u53d1\u5e03\u51fa\u6765\u3002)<\/p>\n<h1>\u7ecf\u8fc7<\/h1>\n<p>\u534a\u5e74\u4e0d\u53c2\u4e0e\u540e\u7aef\u5f00\u53d1\u5de5\u4f5c\u540e\uff0c\u6211\u5fd8\u8bb0\u4e86\u5f88\u591a\u4e1c\u897f\uff08\u6c57\uff09\u2026\u4e3a\u4e86\u590d\u4e60\uff0c\u6211\u51b3\u5b9a\u521b\u5efa\u4e00\u4e2a\u80fd\u8fdb\u884cSQL\u3001\u6570\u636e\u5e93\u6784\u5efa\u548c\u8bbe\u7f6e\u5b9e\u9a8c\u64cd\u4f5c\u7684\u73af\u5883\u3002\u8981\u7406\u89e3SQL\u64cd\u4f5c\u548cPostgreSQL\u7684\u6784\u5efa\u548c\u8bbe\u7f6e\uff0c\u7f51\u7edc\u4e0a\u6709\u5f88\u591a\u5f88\u68d2\u7684\u73af\u5883\u53ef\u4f9b\u4f7f\u7528\uff0c\u4f46\u51fa\u4e8e\u4ee5\u4e0b\u539f\u56e0\uff0c\u6211\u7279\u610f\u51b3\u5b9a\u5728Docker\u5bb9\u5668\u4e0a\u521b\u5efa\u53ef\u8fd0\u884c\u7684PostgreSQL\u5bb9\u5668\u548c\u955c\u50cf\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b3\u30f3\u30c6\u30ca(Docker)\u64cd\u4f5c\u306e\u5fa9\u7fd2\u304c\u3057\u305f\u3044\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u5f8c\u65e5\u3001\u30b3\u30f3\u30c6\u30ca\u9593\u3067\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u30de\u30eb\u30c1\u30af\u30e9\u30b9\u30bf\u74b0\u5883\u69cb\u7bc9\u3092\u8a66\u3057\u3066\u307f\u305f\u3044\u3068\u8003\u3048\u3066\u3044\u3066\u3001\u3044\u3064\u3067\u3082\u7c21\u5358\u306b\u69cb\u7bc9\u3067\u304d\u308b\u3088\u3046\u306b\u30a4\u30e1\u30fc\u30b8\u5316\u3057\u3066\u304a\u304d\u305f\u3044\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u30db\u30b9\u30c8OS\u74b0\u5883\u3092\u6c5a\u3057\u305f\u304f\u306a\u3044\u3002<\/ul>\n<h1>\u672c\u6b21\u7684\u76ee\u6807<\/h1>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d49f337434c4406cb1699\/5-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2020-01-30 \u5348\u524d6.12.27.png\" \/><\/div>\n<p>\u4ece\u5b89\u88c5\u4e86PostgreSQL\u670d\u52a1\u5668\u7684CentOS\u5bb9\u5668\u6620\u50cf\u4e2d\u751f\u6210\u5bb9\u5668\uff0c\u5e76\u542f\u52a8PostgreSQL\u670d\u52a1\u5668\u3002\u4f7f\u7528\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u4e0a\u7684\u5ba2\u6237\u7aef\u8f6f\u4ef6\u8f93\u5165SQL\uff0c\u4ee5\u4fbf\u53ef\u4ee5\u66f4\u65b0\u5bb9\u5668\u5185\u7684PostgreSQL\u670d\u52a1\u5668\u4e0a\u7684\u6570\u636e\u5e93\u3002<\/p>\n<p>\u5728\u672c\u6b21\u6784\u5efa\u4e2d\u4e0d\u8003\u8651\u4ee5\u4e0b\u56e0\u7d20\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b3\u30f3\u30c6\u30ca\u9593\u306e\u63a5\u7d9a\u306f\u3057\u306a\u3044\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>\u4eca\u5f8c\u30de\u30eb\u30c1\u30af\u30e9\u30b9\u30bf\u74b0\u5883\u306e\u69cb\u7bc9\u3092\u5b9f\u73fe\u3059\u308b\u305f\u3081\u306b\u3001\u30b3\u30f3\u30c6\u30ca\u9593\u306e\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u3082\u8003\u616e\u3059\u308b\u5fc5\u8981\u306f\u3042\u308b\u3002\u3057\u304b\u3057\u3001\u4eca\u56de\u306f\u8a2d\u5b9a\u305b\u305a\u3001\u30db\u30b9\u30c8OS\u306e\u307f\u304b\u3089\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u7d4c\u7531\u3067\u30b3\u30f3\u30c6\u30caOS\u306bSQL\u3092\u8981\u6c42\u3059\u308b\u3088\u3046\u306b\u3059\u308b\u3002<\/p>\n<p>\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3084\u30a2\u30af\u30bb\u30b9\u5236\u5fa1<\/p>\n<p>\u540c\u4e00PC\u3068\u306f\u3044\u3048\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u3084\u30a2\u30af\u30bb\u30b9\u5236\u5fa1\u306f\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u304c\u671b\u307e\u3057\u3044\u3002\u3057\u304b\u3057\u3001\u4eca\u56de\u306fSQL\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30b5\u30fc\u30d0\u5185\u90e8\u306e\u5b66\u3073\u7528\u74b0\u5883\u306a\u306e\u3067\u8003\u616e\u3057\u306a\u3044\u3002<\/p>\n<p>\u30c7\u30fc\u30bf\u306e\u6c38\u7d9a\u5316<\/p>\n<p>DB\u30c7\u30fc\u30bf\u6c38\u7d9a\u306e\u305f\u3081\u306b\u30db\u30b9\u30c8OS\u4e0a\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u5171\u6709\u5316(\u30de\u30a6\u30f3\u30c8\u5316)\u3059\u308b\u3053\u3068\u3082\u53ef\u80fd\u3060\u304c\u3001\u4eca\u56de\u306f\u8003\u616e\u3057\u306a\u3044\u3002<\/p>\n<h1>Docker\u955c\u50cf\u521b\u5efa\u73af\u5883<\/h1>\n<p>\u8fd9\u6b21\u7684\u73af\u5883\u8bbe\u7f6e\u5982\u4e0b\uff1a<br \/>\n\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u9009\u62e9\u4e86MacOS\uff0c\u5bb9\u5668\u64cd\u4f5c\u7cfb\u7edf\u9009\u62e9\u4e86CentOS\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30db\u30b9\u30c8OS: Mac v10.15.2<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">Docker Engine: v19.03.5<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b3\u30f3\u30c6\u30caOS:(CentOS\u306fVer7\u3068Ver8\u306e\u4e21\u65b9\u3092\u8a66\u3057\u3066\u307f\u307e\u3057\u305f\u3002)<\/ul>\n<\/li>\n<\/ul>\n<p>CentOS-7 v7.7.1908 (\u30d9\u30fc\u30b9\u30a4\u30e1\u30fc\u30b8\u5143\u306f&#8221;centos:7&#8243;)<br \/>\nCentOS-8 v8.1.1911 (\u30d9\u30fc\u30b9\u30a4\u30e1\u30fc\u30b8\u5143\u306f&#8221;centos:8&#8243;)<\/p>\n<p>PostgreSQL: v12.1 (\u69cb\u7bc9\u6642\u306e\u30bf\u30a4\u30df\u30f3\u30b0\u3067\u306f\u3001CentOS\u6a19\u6e96\u30ea\u30dd\u30b8\u30c8\u30ea\u306bver12\u304c\u306a\u3044\u3088\u3046\u3060\u3063\u305f\u306e\u3067\u3001PostgreSQL\u6a19\u6e96\u30ea\u30dd\u30b8\u30c8\u30ea\u304b\u3089\u53d6\u5f97\u3059\u308b\u3053\u3068\u306b\u3057\u307e\u3057\u305f\u3002)<\/p>\n<h1>\u5c06Docker\u6620\u50cf\u7d20\u6750\u5316\u7684\u65b9\u6cd5\u3002<\/h1>\n<p>\u5728\u4e2d\u6587\u4e2d\u53ef\u4ee5\u8fd9\u6837\u8868\u8fbe\uff1a\u5173\u4e8e\u5f62\u8c61\u5316\u624b\u6bb5\uff0c\u53ef\u4ee5\u8003\u8651\u4ee5\u4e0b\u4e24\u79cd\u65b9\u6cd5\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u65b9\u6cd51 Commit\u306b\u3088\u308b\u30a4\u30e1\u30fc\u30b8\u751f\u6210<\/ul>\n<\/li>\n<\/ul>\n<p>\u30d9\u30fc\u30b9\u3068\u306a\u308b\u30a4\u30e1\u30fc\u30b8\u304b\u3089\u30b3\u30f3\u30c6\u30ca\u3092\u751f\u6210\u8d77\u52d5\u3057\u3001\u30b3\u30f3\u30c6\u30ca\u4e0a\u3067\u624b\u52d5\u306b\u3088\u308a\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30fb\u8a2d\u5b9a\u3092\u884c\u3063\u305f\u72b6\u614b\u306e\u3082\u306e\u3092\u30a4\u30e1\u30fc\u30b8\u5316\u3059\u308b\u3002<\/p>\n<p>\u65b9\u6cd52 DOCKERFILE\u306b\u3088\u308b\u30a4\u30e1\u30fc\u30b8\u751f\u6210<\/p>\n<p>\u30d9\u30fc\u30b9\u3068\u306a\u308b\u30a4\u30e1\u30fc\u30b8\u3092\u57fa\u306b\u3057\u3066\u3001\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30fb\u8a2d\u5b9a\u624b\u9806\u3092DOCKERFILE\u306b\u3088\u308a\u8a18\u8ff0\u3057\u3001\u30a4\u30e1\u30fc\u30b8\u5316\u3059\u308b\u3002<\/p>\n<p>\u5efa\u8bae\u4e0d\u8981\u901a\u8fc7\u7ec8\u7aef\u624b\u52a8\u5b89\u88c5\u5bb9\u5668\uff0c\u800c\u662f\u9075\u5faa\u4ee3\u7801\u5373\u57fa\u7840\u8bbe\u65bd\u7684\u539f\u5219\uff0c\u8003\u8651\u5230\u914d\u7f6e\u548c\u8bbe\u7f6e\u7684\u660e\u786e\u5316\u4ee5\u53ca\u53ef\u91cd\u7528\u6027\uff0c<br \/>\n\u56e0\u4e2a\u4eba\u4e60\u60ef\uff0c\u8bf7\u901a\u8fc7\u65b9\u6cd52\u6765\u5b9e\u73b0\u955c\u50cf\u5316\u7684\u76ee\u6807\u3002<\/p>\n<p>\u5728\u8fdb\u884c\u4e4b\u524d\u7684\u51c6\u5907\u65f6\uff0c\u57fa\u4e8e\u4ee5\u4e0b\u539f\u56e0\uff0c\u6211\u4eec\u51b3\u5b9a\u5148\u8fdb\u884c\u65b9\u6cd51\uff0c\u7136\u540e\u518d\u5b9e\u65bd\u65b9\u6cd52\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30b3\u30f3\u30c6\u30ca\u4e0a\u3067\u6b63\u5e38\u306b\u52d5\u4f5c\u3059\u308b\u306e\u304b\u3001Dockerfile\u306b\u3069\u306e\u3088\u3046\u306a\u9806\u756a\u3067\u66f8\u3051\u3070\u5b9f\u73fe\u3067\u304d\u308b\u304b\u308f\u304b\u3089\u305a\u3001\u78ba\u8a8d\u3057\u305f\u304b\u3063\u305f\u3053\u3068<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u65b9\u6cd5\uff12\u306e\u305f\u3081\u306b\u65e2\u5b58\u30a4\u30e1\u30fc\u30b8\u304b\u3089\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u306e\u53d6\u5f97\u304c\u5fc5\u8981\u3002<\/ul>\n<h2>\u65b9\u6cd51\uff1a\u4f7f\u7528Commit\u6765\u751f\u6210\u56fe\u50cf\u3002<\/h2>\n<p>\u6211\u4eec\u5c06\u6309\u7167\u4ee5\u4e0b\u7684\u6b65\u9aa4\u8fdb\u884c\u56fe\u50cf\u5316\u3002<\/p>\n<p>1-1. \u4e0b\u8f7dCent OS\u955c\u50cf\uff0c\u751f\u6210\u5bb9\u5668<br \/>\n1-2. \u4e0b\u8f7d\u548c\u5b89\u88c5PostgreSQL\u6807\u51c6\u4ed3\u5e93\u5305<br \/>\n1-3. \u5b89\u88c5PostgreSQL\u670d\u52a1\u5668\u53ca\u5176\u5468\u8fb9\u7ec4\u4ef6<br \/>\n1-4. \u521d\u59cb\u5316\u6570\u636e\u5e93<br \/>\n1-5. \u542f\u52a8\u6570\u636e\u5e93\u670d\u52a1\u5668<br \/>\n1-6. \u4fee\u6539PostgreSQL\u7684\u914d\u7f6e<br \/>\n1-7. \u8fdb\u884c\u64cd\u4f5c\u786e\u8ba4<br \/>\n1-8. \u786e\u8ba4\u4ece\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u7684\u8fde\u63a5<br \/>\n1-9. \u5c06\u5bb9\u5668\u955c\u50cf\u5236\u4f5c\u6210\u955c\u50cf\u7248\u672c<br \/>\n1-10. \u9a8c\u8bc1\u521b\u5efa\u7684\u955c\u50cf\u7684\u53ef\u8fd0\u884c\u6027<\/p>\n<p>\u5728\u5b89\u88c5CentOS\u4e0a\u7684PostgreSQL\u7684\u6b65\u9aa4\u4e2d\uff0c\u6211\u53c2\u8003\u4e86\u4ee5\u4e0b\u6587\u7ae0\u3002<\/p>\n<blockquote><p>\u8981\u5728CentOS\u4e0a\u5b89\u88c5PostgreSQL\uff0c\u53ef\u4ee5\u53c2\u8003\u4ee5\u4e0b\u6b65\u9aa4\u3002<\/p><\/blockquote>\n<h3>1-1. \u4e0b\u8f7dCentOS\u955c\u50cf\uff0c\u5e76\u521b\u5efa\u5bb9\u5668\u3002<\/h3>\n<p>\u6253\u5f00\u7ec8\u7aef\uff0c\u4f7f\u7528&#8221;docker container run&#8221;\u547d\u4ee4\u4e0b\u8f7d\u57fa\u7840\u955c\u50cf\u5e76\u751f\u6210\u5bb9\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code> CentOS-8\u306e\u30a4\u30e1\u30fc\u30b8\u3092\u4f7f\u3046\u5834\u5408  \r\n     $ docker container run -d --privileged -v (\u30db\u30b9\u30c8OS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea):(\u30b3\u30f3\u30c6\u30caOS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea) -p 10864:5432 --name='method1_cp12' centos:8 \/sbin\/init\r\n\r\n CentOS-7\u306e\u30a4\u30e1\u30fc\u30b8\u3092\u4f7f\u3046\u5834\u5408  \r\n     $ docker container run -d --privileged -v (\u30db\u30b9\u30c8OS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea):(\u30b3\u30f3\u30c6\u30caOS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea) -p 10864:5432 --name='method1_cp12' centos:7 \/sbin\/init\r\n<\/code><\/pre>\n<p>\u70ba\u4e86\u78ba\u8a8d\u4f5c\u696d\u7684\u76ee\u7684\u4f7f\u7528\u7684SQL\u6587\u4ef6\u4ee5\u53ca\u65b9\u6cd52\u6240\u9700\u8981\u7684\uff0c\u5728\u5bb9\u5668\u5167\u90e8\u5275\u5efa\u548c\u4fee\u6539\u8a2d\u5b9a\u6587\u4ef6\uff0c\u6211\u5011\u4f7f\u7528\u4e86&#8221;-v&#8221;\u53c3\u6578\u4ee5\u4fbf\u5728\u4e3b\u6a5f\u548c\u5bb9\u5668\u4e4b\u9593\u9032\u884c\u5171\u4eab\u3002\u9019\u6b21\u6211\u5011\u8a66\u8457\u5728\u4ee5\u4e0b\u4f4d\u7f6e\u9032\u884c\u4e86\u8a2d\u5b9a\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u30db\u30b9\u30c8OS\u5074\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\uff1a\/Users\/(\u30e6\u30fc\u30b6\u540d)\/sampleDocker\/work\/shared_directory<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\u30b3\u30f3\u30c6\u30caOS\u5074\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\uff1a\/var\/shared_directory<\/ul>\n<p>\u53e6\u5916\uff0c\u5728CentOS\u5bb9\u5668\u4e2d\u65e0\u6cd5\u4f7f\u7528systemctl\u547d\u4ee4\u3002\u4e3a\u4e86\u5728\u5bb9\u5668\u4e2d\u4f7f\u7528\uff0c\u53ef\u4ee5\u5728&#8221;docker container run&#8221;\u7684\u9009\u9879\u4e2d\u6dfb\u52a0&#8221;&#8211;privileged&#8221;\u53c2\u6570\u6765\u4f7f\u7528\u3002\u672c\u6b21\u4f7f\u7528\u5b83\u6765\u81ea\u52a8\u542f\u52a8\u548c\u68c0\u67e5PostgreSQL\u670d\u52a1\uff0c\u4ee5\u53ca\u5728&#8221;1-4.\u6570\u636e\u5e93\u670d\u52a1\u5668\u521d\u59cb\u5316&#8221;\u4e2d\u7684\u521d\u59cb\u5316shell\u811a\u672c\u4e2d\u6267\u884csystemctl\u547d\u4ee4\uff0c\u6240\u4ee5\u9700\u8981\u5728\u5bb9\u5668\u4e2d\u6267\u884cSystemctl\u547d\u4ee4\u3002<\/p>\n<blockquote><p>(\u53c3\u8003) \u5728 CentOS7 \u7684 Docker \u5bb9\u5668\u4e2d\u555f\u7528 systemctl<\/p><\/blockquote>\n<p>\u4e3a\u4e86\u5728\u5bb9\u5668\u5185\u8fdb\u884c\u64cd\u4f5c\uff0c\u8bf7\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\u5e76\u8fdb\u5165\u5bb9\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ docker container exec -it method1_cp12 \/bin\/bash\r\n<\/code><\/pre>\n<h3>1-2. \u4e0b\u8f7d\u5e76\u5b89\u88c5PostgreSQL\u7684\u6807\u51c6\u4ed3\u5e93\u5305\u3002<\/h3>\n<p>\u65e2\u7136\u6709\u8fd9\u4e2a\u673a\u4f1a&#8230;\u5728CentOS-8\u4e0a\uff0c\u6211\u51b3\u5b9a\u4f7f\u7528dnf\u547d\u4ee4\u8fdb\u884c\u5b89\u88c5\u3002<\/p>\n<pre class=\"post-pre\"><code> CentOS-8\u306e\u5834\u5408  \r\n     # dnf -y install https:\/\/download.postgresql.org\/pub\/repos\/yum\/reporpms\/EL-8-x86_64\/pgdg-redhat-repo-latest.noarch.rpm\r\n     # dnf -qy module disable postgresql\r\n\r\n CentOS-7\u306e\u5834\u5408\r\n     # yum -y install https:\/\/download.postgresql.org\/pub\/repos\/yum\/reporpms\/EL-7-x86_64\/pgdg-redhat-repo-latest.noarch.rpm\r\n<\/code><\/pre>\n<h3>1-3. \u5b89\u88c5PostgreSQL\u670d\u52a1\u5668\uff08\u53ca\u5176\u5468\u8fb9\u8bbe\u5907\uff09\u3002<\/h3>\n<p>\u6211\u8981\u5b89\u88c5PostgreSQL\u3002\u5728\u4e4b\u540e\u7684\u64cd\u4f5c\u4e2d\uff0c\u9700\u8981\u521b\u5efa\u7528\u6237\u5bc6\u7801\uff0c\u4f46\u662f\u56e0\u4e3aCentOS\u4e2d\u6ca1\u6709\u5b89\u88c5&#8221;passwd&#8221;\uff0c\u6240\u4ee5\u6211\u9700\u8981\u8fdb\u884c\u5b89\u88c5\u3002<\/p>\n<pre class=\"post-pre\"><code> CentOS-8\u306e\u5834\u5408  \r\n     # dnf -y install postgresql12-server postgresql12 postgresql12-contrib\r\n     # dnf -y install passwd\r\n\r\n CentOS-7\u306e\u5834\u5408\r\n     # yum -y install postgresql12-server postgresql12 postgresql12-contrib\r\n     # yum -y install passwd\r\n<\/code><\/pre>\n<h3>1-4. \u6570\u636e\u5e93\u7684\u521d\u59cb\u5316<\/h3>\n<p>\u8fdb\u884c\u6570\u636e\u5e93\u7684\u521d\u59cb\u5316\u3002<\/p>\n<pre class=\"post-pre\"><code>     # PGSETUP_INITDB_OPTIONS=\"-E UTF8 --no-locale\" \/usr\/pgsql-12\/bin\/postgresql-12-setup initdb\r\n<\/code><\/pre>\n<h3>1-5. \u6570\u636e\u5e93\u670d\u52a1\u5668\u542f\u52a8<\/h3>\n<p>\u542f\u52a8PostgreSQL\u670d\u52a1\u3002<\/p>\n<pre class=\"post-pre\"><code>    # systemctl start postgresql-12.service\r\n<\/code><\/pre>\n<p>\u6211\u5c06\u68c0\u67e5\u670d\u52a1\u662f\u5426\u6b63\u5e38\u5de5\u4f5c\u3002<\/p>\n<pre class=\"post-pre\"><code>    # systemctl status postgresql-12.service\r\n<\/code><\/pre>\n<p>\u6267\u884c\u540e\uff0c\u5982\u679c\u201cpostgresql-12.service\u201d\u7684\u6d3b\u52a8\u72b6\u6001\u663e\u793a\u4e3a\u201cactive(running)\u201d\u5219\u8868\u793a\u6b63\u5e38\u3002<\/p>\n<h3>1-6. \u66f4\u6539PostgreSQL\u7684\u8bbe\u7f6e<\/h3>\n<p>\u8bf7\u5c06\u8bbe\u7f6e\u66f4\u6539\u4e3aSQL\u5ba2\u6237\u7aef\u8f6f\u4ef6\u53ef\u4ee5\u4ece\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u8bbf\u95ee\u3002<br \/>\n\u53e6\u5916\uff0c\u4e3a\u4e86\u521b\u5efa\u6620\u50cf\uff0c\u5728\u65b9\u6cd5\u4e8c\u4e2d\u5c06\u914d\u7f6e\u6587\u4ef6\u548c\u811a\u672c\u590d\u5236\u5230\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u4e0a\u3002\uff08\u8bf7\u6ce8\u610f\uff0c\u6b64\u5904\u8bf4\u660e\u7684\u8bbe\u7f6e\u4ec5\u7528\u4e8e\u5b9e\u9a8c\u76ee\u7684\uff0c\u5e76\u672a\u8003\u8651\u5b89\u5168\u6027\u3002\u8bf7\u6839\u636e\u4f7f\u7528\u76ee\u7684\u548c\u5efa\u7acb\u73af\u5883\u8fdb\u884c\u4e2a\u4eba\u8c03\u6574\u3002\uff09<\/p>\n<p>\u4f7f\u7528\u6587\u672c\u7f16\u8f91\u5668\uff08\u5728\u6b64\u793a\u4f8b\u4e2d\u4f7f\u7528vi\uff09\uff0c\u6253\u5f00\/var\/lib\/pgsql\/12\/data\/postgresql.conf\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>    # vi \/var\/lib\/pgsql\/12\/data\/postgresql.conf\r\n<\/code><\/pre>\n<p>\u6211\u5011\u5c0b\u627e\u300clisten_addresses =\u300d\u9019\u4e00\u884c\uff0c\u7136\u5f8c\u9032\u884c\u4ee5\u4e0b\u7684\u4fee\u6539\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">#listen_address = &#8216;localhost&#8217;\u306e\u30b3\u30e1\u30f3\u30c8\u90e8\u5206(#)\u3092\u6d88\u3059\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">#port = 5432\u306e\u30b3\u30e1\u30f3\u30c8\u90e8\u5206(#)\u3092\u6d88\u3059\u3002<\/ul>\n<\/li>\n<\/ul>\n<p>listen_address = &#8216;localhost&#8217;\u306e&#8217;localhost&#8217;\u3092&#8217;*&#8217;\u306b\u5909\u66f4\u3002<\/p>\n<p>\/var\/lib\/pgsql\/12\/data\/postgresql.conf<br \/>\n[\u5909\u66f4\u524d]<br \/>\n# &#8211; Connection Settings &#8211;<br \/>\n#listen_addresses = &#8216;localhost&#8217; # what IP address(es) to listen on;<br \/>\n# comma-separated list of addresses;<br \/>\n# defaults to &#8216;localhost&#8217;; use &#8216;*&#8217; for all<br \/>\n# (change requires restart)<br \/>\n#port = 5432 # (change requires restart)<br \/>\nmax_connections = 100 # (change requires restart)<\/p>\n<p>[\u5909\u66f4\u5f8c]<br \/>\n# &#8211; Connection Settings &#8211;<br \/>\nlisten_addresses = \u2018*&#8217; # what IP address(es) to listen on;<br \/>\n# comma-separated list of addresses;<br \/>\n# defaults to &#8216;localhost&#8217;; use &#8216;*&#8217; for all<br \/>\n# (change requires restart)<br \/>\nport = 5432 # (change requires restart)<br \/>\nmax_connections = 100 # (change requires restart)<\/p>\n<p>\u4fdd\u5b58postgresql.conf\u6587\u4ef6\u5e76\u9000\u51fa\u6587\u672c\u7f16\u8f91\u5668\u3002<br \/>\n\uff08\u901a\u8fc7\u4e0a\u8ff0\u8bbe\u7f6e\u5c06listen_addresses\u914d\u7f6e\u4e3a&#8217;*&#8217;\uff0c\u53ef\u4ee5\u63a5\u6536\u4efb\u4f55\u8fde\u63a5\uff0c\u4f46\u7531\u4e8e\u8fd9\u662f\u7528\u4e8e\u5b9e\u9a8c\uff0c\u6240\u4ee5\u9009\u62e9\u4e86\u8fd9\u4e2a\u8bbe\u7f6e\u3002\uff09<\/p>\n<p>\u4f7f\u7528\u6587\u672c\u7f16\u8f91\u5668\u6253\u5f00\/var\/lib\/pgsql\/12\/data\/pg_hba.conf\u3002<\/p>\n<pre class=\"post-pre\"><code>    # vi \/var\/lib\/pgsql\/12\/data\/pg_hba.conf\r\n<\/code><\/pre>\n<p>\u6211\u8981\u6dfb\u52a0\u4ee5\u4e0b\u4e00\u884c\uff1a<br \/>\n&#8220;host all all 0.0.0.0\/0 md5&#8221;<\/p>\n<pre class=\"post-pre\"><code>    &lt;\/var\/lib\/pgsql\/12\/data\/pg_hba.conf&gt;\r\n\r\n    [\u5909\u66f4\u524d]\r\n          # \"local\" is for Unix domain socket connections only\r\n          local   all             all                                     peer\r\n          # IPv4 local connections:\r\n          host    all             all             127.0.0.1\/32            ident\r\n          # IPv6 local connections: \r\n          host    all             all             ::1\/128                 ident\r\n\r\n    [\u5909\u66f4\u5f8c]\r\n          # \"local\" is for Unix domain socket connections only\r\n          local   all             all                                     peer\r\n          # IPv4 local connections:\r\n          host    all             all             127.0.0.1\/32            ident\r\n          host    all             all             0.0.0.0\/0               md5\r\n\r\n          # IPv6 local connections: \r\n          host    all             all             ::1\/128                 ident\r\n<\/code><\/pre>\n<p>\u4fdd\u5b58pg_hba.conf\u6587\u4ef6\u5e76\u9000\u51fa\u6587\u672c\u7f16\u8f91\u5668\u3002<\/p>\n<p>\u8bbe\u7f6epostgres\u7528\u6237\u7684\u5bc6\u7801\u3002<br \/>\npostgres\u7528\u6237\u65e2\u6ce8\u518c\u4e3a\u64cd\u4f5c\u7cfb\u7edf\u7528\u6237\uff0c\u4e5f\u6ce8\u518c\u4e3aPostgreSQL\u7528\u6237\uff0c<br \/>\n\u56e0\u6b64\u9700\u8981\u8fdb\u884c\u4e24\u79cd\u5bc6\u7801\u7684\u6ce8\u518c\uff0c\u4ee5\u4fbf\u4ece\u5916\u90e8\u90fd\u80fd\u591f\u8bbf\u95ee\u3002<br \/>\n\uff08\u5728\u6b64\u793a\u4f8b\u4e2d\uff0c\u5c06\u9ed8\u8ba4\u7528\u6237&#8217;postgres&#8217;\u7684\u5bc6\u7801\u6ce8\u518c\u4e3a&#8217;postgres&#8217;\u3002\uff09<\/p>\n<p>\u5728\u7b2c\u4e8c\u4e2a\u6b65\u9aa4\u4e2d\uff0c\u7531\u4e8e\u9700\u8981\u5728\u56fe\u50cf\u751f\u6210\u65f6\u6267\u884c\u76f8\u540c\u7684\u547d\u4ee4\uff0c\u56e0\u6b64\u9700\u8981\u8fdb\u884c\u811a\u672c\u5316\uff0c\u5e76\u66f4\u6539PostgreSQL\u7528\u6237\u7684\u8bbe\u7f6e\u3002<br \/>\n\u51c6\u5907\u4e24\u4e2ashell\u811a\u672c\uff0c\u547d\u540d\u5982\u4e0b\uff1a<br \/>\n&#8211; setting_postgresql.sh<br \/>\n&#8211; setting_postgresqluser.sh<\/p>\n<p>\u65b0\u5efa\u4e00\u4e2a\u540d\u4e3a\u201csetting_postgresql.sh\u201d\u7684\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>    # vi \/var\/lib\/pgsql\/setting_postgresql.sh\r\n<\/code><\/pre>\n<p>\u5c06&#8221;setting_postgresql.sh&#8221;\u6587\u4ef6\u7684\u5185\u5bb9\u5982\u4e0b\u6240\u793a\u8fdb\u884c\u7f16\u5199\u5e76\u4fdd\u5b58\uff0c\u7136\u540e\u5173\u95ed\u6587\u672c\u7f16\u8f91\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>    #!\/bin\/bash\r\n\r\n    echo 'postgres' | passwd --stdin postgres\r\n    su -l postgres -c \".\/setting_postgresqluser.sh\"\r\n<\/code><\/pre>\n<p>\u521b\u5efa\u65b0\u7684&#8221;setting_postgresqluser.sh&#8221;\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>    # vi \/var\/lib\/pgsql\/setting_postgresqluser.sh\r\n<\/code><\/pre>\n<p>\u5c06&#8221;setting_postgresqluser.sh&#8221;\u6587\u4ef6\u7684\u5185\u5bb9\u5982\u4e0b\u6240\u793a\u8fdb\u884c\u4fdd\u5b58\uff0c\u5e76\u5173\u95ed\u6587\u672c\u7f16\u8f91\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>    #!\/bin\/bash\r\n\r\n    psql -c \"ALTER ROLE postgres WITH password 'postgres'\"\r\n<\/code><\/pre>\n<p>\u8bbe\u7f6e\u4e24\u4e2ashell\u811a\u672c\u7684\u6267\u884c\u6743\u9650\u3002<\/p>\n<pre class=\"post-pre\"><code>   # chmod +x \/var\/lib\/pgsql\/setting_postgresql.sh\r\n   # chmod +x \/var\/lib\/pgsql\/setting_postgresqluser.sh\r\n<\/code><\/pre>\n<p>\u6267\u884c\u4ee5\u4e0b\u64cd\u4f5c\uff0c\u8fd9\u6837\u53ef\u4ee5\u4e3a\u7528\u6237&#8221;postgres&#8221;\u6ce8\u518c\u5bc6\u7801\u3002<\/p>\n<pre class=\"post-pre\"><code>   # \/var\/lib\/pgsql\/setting_postgresql.sh\r\n<\/code><\/pre>\n<p>\u4e3a\u4e86\u5728\u65b9\u6cd52\u4e2d\u8fdb\u884c\u540e\u7eed\u64cd\u4f5c\uff0c\u8fd9\u6b21\u66f4\u6539\u7684\u914d\u7f6e\u6587\u4ef6\u548c\u521b\u5efa\u7684shell\u811a\u672c\u5c06\u4fdd\u5b58\u57281-1\u4e2d\u521b\u5efa\u7684\u5171\u4eab\u76ee\u5f55(\/var\/shared_directory)\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code>   # cp \/var\/lib\/pgsql\/12\/data\/postgresql.conf \/var\/shared_directory\/\r\n   # cp \/var\/lib\/pgsql\/12\/data\/pg_hba.conf \/var\/shared_directory\/\r\n   # cp \/var\/lib\/pgsql\/setting_postgresql.sh \/var\/shared_directory\/\r\n   # cp \/var\/lib\/pgsql\/setting_postgresqluser.sh \/var\/shared_directory\/\r\n<\/code><\/pre>\n<p>\u53e6\u5916\uff0c\u5728\u6267\u884c\u65b9\u6cd52\u4e4b\u524d\uff0c\u9700\u8981\u5148\u4fee\u6539\u4ee5\u4e0b\u6587\u4ef6\uff0c\u56e0\u6b64\u5c06\u5176\u590d\u5236\u3002<\/p>\n<pre class=\"post-pre\"><code>   # cp \/usr\/pgsql-12\/bin\/postgresql-12-setup \/var\/shared_directory\/\r\n<\/code><\/pre>\n<p>\u5728\u5bb9\u5668\u542f\u52a8\u65f6\uff0c\u5c06\u6ce8\u518c\u8bbe\u7f6e\u4e3a\u81ea\u52a8\u542f\u52a8\uff08\u6301\u7eed\u8fd0\u884c\uff09PostgreSQL\u670d\u52a1\u3002<\/p>\n<pre class=\"post-pre\"><code>   # systemctl enable postgresql-12.service\r\n<\/code><\/pre>\n<p>\u4e3a\u4e86\u53cd\u6620\u4e4b\u524d\u7684\u8bbe\u7f6e\uff0c\u6211\u4eec\u5c06\u91cd\u65b0\u542f\u52a8\u3002<\/p>\n<pre class=\"post-pre\"><code>   # systemctl restart postgresql-12.service\r\n<\/code><\/pre>\n<h3>1-7. Action confirmation<br \/>\n1. \u884c\u52a8\u786e\u8ba4<br \/>\n2. \u52a8\u4f5c\u786e\u8ba4<br \/>\n3. \u786e\u8ba4\u884c\u52a8<br \/>\n4. \u786e\u8ba4\u52a8\u4f5c<br \/>\n5. \u786e\u8ba4\u6d3b\u52a8<br \/>\n6. \u884c\u4e3a\u786e\u8ba4<br \/>\n7. \u52a8\u4f5c\u9a8c\u8bc1<\/h3>\n<p>\u4e3a\u4e86\u786e\u8ba4\u64cd\u4f5c\uff0c\u6211\u4eec\u5c06\u8fdb\u884c\u4e00\u9879\u64cd\u4f5c\u786e\u8ba4\u3002<br \/>\n\u4e3a\u4e86\u786e\u8ba4\u6570\u636e\u5e93\u670d\u52a1\u5668\u7684\u64cd\u4f5c\uff0c\u6211\u4eec\u5c1d\u8bd5\u521b\u5efa\u4e00\u4e2a\u5305\u542b\u8868\u683c\u548c\u63d2\u5165\u6570\u636e\u7684SQL\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>   # vi \/var\/shared_directory\/sampleSQL.sql\r\n<\/code><\/pre>\n<p>\u5728SQL\u6587\u4ef6\u4e2d\u5199\u4e0b\u4ee5\u4e0b\u5185\u5bb9\uff0c\u5e76\u4fdd\u5b58\u3002\u5173\u95ed\u6587\u672c\u7f16\u8f91\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>  sql:\/var\/shared_directory\/sampleSQL.sql\r\n\r\n   CREATE TABLE \u679c\u7269 (\r\n       ID INTEGER PRIMARY KEY,\r\n       \u540d\u524d VARCHAR(40) UNIQUE\r\n   );\r\n   CREATE TABLE \u679c\u7269\u58f2\u8cb7\u53d6\u5f15 (\r\n       \u53d6\u5f15ID SERIAL PRIMARY KEY,\r\n       \u53d6\u5f15\u65e5\u4ed8 DATE,\r\n       \u679c\u7269ID INTEGER REFERENCES \u679c\u7269(ID),\r\n       \u30e1\u30e2 VARCHAR(100) DEFAULT '\u4e0d\u660e',\r\n       \u8cb7\u53d6\u984d INTEGER DEFAULT 0 CHECK(\u8cb7\u53d6\u984d&gt;= 0),\r\n       \u58f2\u5374\u984d INTEGER DEFAULT 0 CHECK(\u58f2\u5374\u984d&gt;= 0),\r\n       \u500b\u6570 INTEGER DEFAULT 0 CHECK(\u500b\u6570&gt;= 0)\r\n   );\r\n   INSERT INTO \u679c\u7269(ID, \u540d\u524d)\r\n      VALUES (0, '\u30aa\u30ec\u30f3\u30b8');\r\n      INSERT INTO \u679c\u7269(ID, \u540d\u524d)\r\n      VALUES (1, '\u30a2\u30c3\u30d7\u30eb');\r\n   INSERT INTO \u679c\u7269(ID, \u540d\u524d)\r\n      VALUES (2, '\u30d0\u30ca\u30ca');\r\n   INSERT INTO \u679c\u7269\u58f2\u8cb7\u53d6\u5f15(\u53d6\u5f15\u65e5\u4ed8, \u679c\u7269ID, \u8cb7\u53d6\u984d, \u500b\u6570)\r\n      VALUES ('2018-04-02', 1, 1200, 10);\r\n   INSERT INTO \u679c\u7269\u58f2\u8cb7\u53d6\u5f15(\u53d6\u5f15\u65e5\u4ed8, \u679c\u7269ID, \u8cb7\u53d6\u984d, \u500b\u6570)\r\n      VALUES ('2018-04-05', 2, 1500, 6);\r\n   INSERT INTO \u679c\u7269\u58f2\u8cb7\u53d6\u5f15(\u53d6\u5f15\u65e5\u4ed8, \u679c\u7269ID, \u8cb7\u53d6\u984d, \u500b\u6570)\r\n      VALUES ('2018-04-06', 0, 2000, 8);\r\n<\/code><\/pre>\n<p>\u6267\u884cSQL\u6587\u4ef6\u3002<\/p>\n<pre class=\"post-pre\"><code>   # su - postgres\r\n   $ cd \/var\/shared_directory\/\r\n   $ psql -f .\/sampleSQL.sql\r\n<\/code><\/pre>\n<p>\u6211\u4eec\u4f1a\u786e\u8ba4\u8868\u683c\u548c\u63d2\u5165\u7684\u6570\u636e\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ psql -d postgres -c \"select * from \u679c\u7269\u58f2\u8cb7\u53d6\u5f15\"\r\n<\/code><\/pre>\n<p>\u5f53\u6570\u636e\u5df2\u786e\u8ba4\u65e0\u8bef\u540e\uff0c\u5c06\u6ce8\u9500&#8221;postgres&#8221;\u7528\u6237\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ logout\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u5904\u4e8e\u5bb9\u5668\u767b\u5f55\u72b6\u6001\uff0c\u6211\u6682\u65f6\u9000\u51fa\u3002<\/p>\n<pre class=\"post-pre\"><code>    # exit\r\n<\/code><\/pre>\n<h3>1-8. \u4ece\u4e3b\u64cd\u4f5c\u7cfb\u7edf\u786e\u8ba4\u8fde\u63a5<\/h3>\n<p>\u6211\u4eec\u5c06\u4ece\u4e3b\u673a\u7aef\u8fdb\u884c\u8fde\u63a5\u786e\u8ba4\u3002\u867d\u7136\u53ef\u4ee5\u5728\u4e3b\u673a\u7aef\u5b89\u88c5psql\uff0c\u4f46\u8fd9\u6b21\u6211\u4f7f\u7528TablePlus\u4f5c\u4e3a\u5ba2\u6237\u7aef\u8f6f\u4ef6\u8fdb\u884c\u786e\u8ba4\u3002<\/p>\n<p>TablePlus\u7684\u8bbe\u7f6e\u5927\u81f4\u5982\u6b64\u3002<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d49f337434c4406cb1699\/97-0.png\" alt=\"image.png\" \/><\/div>\n<p>\u5b8c\u6210\u540e\uff0c\u60a8\u53ea\u9700\u8fde\u63a5\u5e76\u786e\u8ba4\u4e4b\u524d\u521b\u5efa\u7684\u8868\u662f\u5426\u53ef\u4ee5\u8fdb\u884cSQL\u64cd\u4f5c\u5373\u53ef\u3002<\/p>\n<h3>1-9. \u5c06\u5bb9\u5668\u56fe\u50cf\u5316<\/h3>\n<p>\u4f7f\u7528docker\u5bb9\u5668\u63d0\u4ea4\u547d\u4ee4`docker container commit`\u53ef\u4ee5\u521b\u5efa\u6b63\u5728\u8fd0\u884c\u7684\u5bb9\u5668\u7684Docker\u955c\u50cf\u3002\u9009\u9879-a\u8868\u793a\u521b\u5efa\u8005\uff0c-c\u8868\u793a\u5bb9\u5668\u5185\u90e8\u7aef\u53e3\u53f7\uff08\u5f53\u6267\u884cdocker container run\u547d\u4ee4\u65f6\u6ca1\u6709\u6307\u5b9a\u7aef\u53e3\u65f6\u9002\u7528\uff09\u3002\u6700\u540e\u8f93\u5165\u955c\u50cf\u540d\u79f0\u3002\u4f8b\u5982\uff0c&#8221;gomadofu\/method1_cp12:1&#8243;\u4e2d\uff0c&#8221;gomadofu\/method1_cp12&#8243;\u662f\u955c\u50cf\u540d\u79f0\uff0c&#8221;1&#8243;\u662f\u6807\u7b7e\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ docker container commit -a \"GOMA DOFU\" -c \"EXPOSE 5432\" -p method1_cp12 gomadofu\/method1_cp12:1\r\n<\/code><\/pre>\n<h3>1-10. \u786e\u8ba4\u6240\u521b\u5efa\u56fe\u50cf\u7684\u52a8\u4f5c\u662f\u5426\u6b63\u5e38\u3002<\/h3>\n<p>\u505c\u6b62\u4e4b\u524d\u4e00\u76f4\u5728\u8fd0\u884c\u7684\u5bb9\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ docker container stop method1_cp12\r\n<\/code><\/pre>\n<p>\u4f7f\u7528\u521b\u5efa\u7684\u201cgomadofu\/method1_cp12:1\u201d\u955c\u50cf\u6765\u751f\u6210\u548c\u542f\u52a8\u5bb9\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ docker container run -d --privileged -v (\u30db\u30b9\u30c8OS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea):(\u30b3\u30f3\u30c6\u30caOS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea) -p 10864:5432 --name='method1_cp12_2' gomadofu\/method1_cp12:1 \/sbin\/init\r\n<\/code><\/pre>\n<p>\u91cd\u65b0\u6267\u884c\u201c1-8.\u4ece\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u786e\u8ba4\u8fde\u63a5\u201d\u7684\u6b65\u9aa4\u3002\u5982\u679c\u786e\u8ba4\u53ef\u4ee5\u8fde\u63a5\uff0c\u5219\u8868\u793a\u5df2\u5b8c\u6210\u3002<\/p>\n<p>\u4e00\u5fdc\uff0c\u901a\u8fc7\u5b8c\u6210\u5230\u8fd9\u4e00\u6b65\u7684\u5de5\u4f5c\uff0c\u6211\u4eec\u53ef\u4ee5\u5c06CentOS\u548cPostgreSQL\u8fdb\u884c\u5bb9\u5668\u5316\uff0c\u5e76\u786e\u8ba4\u4e86\u5176\u7b80\u5355\u7684\u8fd0\u884c\u60c5\u51b5\u3002\u6b64\u5916\uff0c\u6211\u4eec\u8fd8\u51c6\u5907\u4e86\u65b9\u6cd52\u6240\u9700\u7684\u914d\u7f6e\u6587\u4ef6\u548c\u811a\u672c\u3002<\/p>\n<h2>\u7b2c\u4e8c\u79cd\u65b9\u6cd5\u662f\u901a\u8fc7DOCKERFILE\u751f\u6210\u955c\u50cf\u3002<\/h2>\n<p>\u6211\u5011\u5c07\u6309\u7167\u4ee5\u4e0b\u6b65\u9a5f\u4f86\u5275\u5efa\u5716\u7247\u3002<\/p>\n<p>2-1. \u51c6\u5907\u56fe\u50cf\u6784\u5efa\u76ee\u5f55<br \/>\n2-2. \u521b\u5efaDOCKERFILE\u6587\u4ef6<br \/>\n2-3. \u4fee\u6539initdb\u811a\u672c<br \/>\n2-4. \u6267\u884c\u6784\u5efa<br \/>\n2-5. \u542f\u52a8\u5bb9\u5668\uff08\u8fdb\u884c\u64cd\u4f5c\u786e\u8ba4\uff09<\/p>\n<p>\u5728\u8fd9\u6b21\u7684\u5236\u4f5c\u8fc7\u7a0b\u4e2d\uff0c\u4ee4\u4eba\u5934\u75bc\u7684\u95ee\u9898\u662f&#8221;systemctl&#8221;\u547d\u4ee4\u7684\u5b58\u5728\u3002<br \/>\n\u5728\u65b9\u6cd5\u4e00\u4e2d\uff0c\u6211\u4eec\u901a\u8fc7\u5728\u5bb9\u5668\u542f\u52a8\u65f6\u6267\u884c&#8221;&#8211;privileged&#8221;\u547d\u4ee4\u6765\u5728\u5bb9\u5668\u5185\u4f7f\u7528\u5b83\u3002\u7136\u800c\uff0c\u5373\u4f7f\u5728Dockerfile\u4e2d\u5199\u5165&#8221;systemctl&#8221;\u547d\u4ee4\uff0c\u6784\u5efa\u65f6\u4ecd\u7136\u4f1a\u53d1\u751f\u9519\u8bef\u3002<\/p>\n<p>\u521b\u5efa\u4e24\u4e2a\u6620\u50cf\u7684\u65b9\u6cd5\u53ef\u4ee5\u5728dockerfile\u5185\u4f7f\u7528systemctl\u547d\u4ee4\uff08\u786e\u5207\u5730\u8bf4\u662f&#8221;systemctl enable&#8221;\uff09\u6765\u907f\u514d\u8fd9\u4e2a\u95ee\u9898\u3002<\/p>\n<blockquote><p>\uff08\u4ec5\u4f9b\u53c2\u8003\uff09\u8bf7\u67e5\u770b\u4ee5\u4e0b\u94fe\u63a5\uff1ahttps:\/\/hub.docker.com\/_\/centos?tab=description<\/p><\/blockquote>\n<p>\u5c3d\u7ba1\u4e0d\u4f7f\u7528 &#8220;systemctl&#8221; \u547d\u4ee4\u4e5f\u53ef\u4ee5\u542f\u52a8\u3001\u5173\u95ed\u548c\u91cd\u542f\u670d\u52a1\uff0c\u4f46\u4e3a\u4e86\u5728\u5bb9\u5668\u542f\u52a8\u65f6\u81ea\u52a8\u542f\u52a8PostgreSQL\u670d\u52a1\uff0c\u6211\u6253\u7b97\u521b\u5efa\u4e24\u4e2a\u955c\u50cf\u4ee5\u4fbf\u4f7f\u7528&#8221;systemctl enable&#8221;\u547d\u4ee4\u3002<\/p>\n<p>\u53e6\u5916\uff0c\u5728\u201c\u65b9\u6cd51\u76841-4.\u6570\u636e\u5e93\u521d\u59cb\u5316\u201d\u4e2d\u6267\u884c\u7684\u201cpostgresql-12-setup\u201d\u811a\u672c\u4e2d\uff0c\u4f7f\u7528\u4e86systemctl show\u547d\u4ee4\uff0c\u5bfc\u81f4\u5728\u6784\u5efa\u65f6\u51fa\u73b0\u9519\u8bef\u3002\u56e0\u6b64\uff0c\u5728\u201c2-3.initdb\u811a\u672c\u7684\u4fee\u6b63\u201d\u4e2d\u9700\u8981\u4fee\u6539\u811a\u672c\u5185\u5bb9\u3002<\/p>\n<h3>2-1. \u51c6\u5907\u7528\u4e8e\u56fe\u50cf\u6784\u5efa\u7684\u76ee\u5f55<\/h3>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d49f337434c4406cb1699\/118-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2020-01-30 \u5348\u524d11.50.57.png\" \/><\/div>\n<p>\u7531\u4e8e\u9700\u8981\u4e3a\u6bcf\u4e2a\u56fe\u50cf\u51c6\u5907\u4e00\u4e2a\u76ee\u5f55\uff0c\u6240\u4ee5\u8fd9\u6b21\u6211\u5c06\u51c6\u5907\u4e24\u4e2a\u76ee\u5f55\u3002<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">CentOS_Systemd \u30c7\u30a3\u30ec\u30af\u30c8\u30ea(\u30a4\u30e1\u30fc\u30b8\u540d:&#8221;gomadofu\/method2_csystemd&#8221;)<\/ul>\n<\/li>\n<\/ul>\n<p>&#8220;systemctl&#8221;\u30b3\u30de\u30f3\u30c9\u304c\u4f7f\u3048\u308bCentOS\u30a4\u30e1\u30fc\u30b8\u3092\u69cb\u6210\u3059\u308bDockerfile\u3092\u683c\u7d0d\u3059\u308b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u3059\u3002<\/p>\n<p>CentOS_Postgresql12 \u30c7\u30a3\u30ec\u30af\u30c8\u30ea(\u30a4\u30e1\u30fc\u30b8\u540d:&#8221;gomadofu\/method2_cp12&#8221;)<\/p>\n<p>PostgreSQL\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30fb\u8a2d\u5b9a\u6e08\u307f\u306eCentOS\u30a4\u30e1\u30fc\u30b8\u3092\u69cb\u6210\u3059\u308bDockerfile\u3092\u683c\u7d0d\u3059\u308b\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u3059\u3002<br \/>\n\u3053\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u306f\u65b9\u6cd5\uff11\u306e\u904e\u7a0b\u3067\u5f97\u3089\u308c\u305f\u3001\u8a2d\u5b9a\u30d5\u30a1\u30a4\u30eb\u3001\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u683c\u7d0d\u3057\u307e\u3059\u3002<\/p>\n<p>postgresql.conf<br \/>\npg_hba.conf<br \/>\nsetting_postgresql.sh<br \/>\nsetting_postgresqluser.sh<br \/>\nPostgresql-12-setup<\/p>\n<h3>2-2.\u521b\u5efaDockerfile<\/h3>\n<p>\u6211\u5c06\u521b\u5efa\u4e00\u4e2aDOCKERFILE\u3002<\/p>\n<h4>DOCKERFILE\u7684\u955c\u50cf\u652f\u6301systemctl\u547d\u4ee4\u3002<\/h4>\n<p>\u5728CentOS_Systemd\u76ee\u5f55\u4e2d\u521b\u5efa\u4e00\u4e2aDockerfile\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ cd .\/CentOS_Systemd\r\n     $ vi .\/Dockerfile \r\n<\/code><\/pre>\n<p>\u8bf7\u5c06\u4ee5\u4e0b\u5185\u5bb9\u5199\u5165Dockerfile\u5e76\u4fdd\u5b58\u3002<\/p>\n<pre class=\"post-pre\"><code>     FROM centos:8\r\n     #centos:7\u3092\u4f7f\u3046\u5834\u5408\u306f \"FROM centos:7\u201d\u306b\u3059\u308b\u3002\r\n\r\n     ENV container docker\r\n\r\n     RUN (cd \/lib\/systemd\/system\/sysinit.target.wants\/; for i in *; do [ $i == systemd-tmpfiles-setup.service ] || rm -f $i; done); \\\r\n     rm -f \/lib\/systemd\/system\/multi-user.target.wants\/*;\\\r\n     rm -f \/etc\/systemd\/system\/*.wants\/*;\\\r\n     rm -f \/lib\/systemd\/system\/local-fs.target.wants\/*; \\\r\n     rm -f \/lib\/systemd\/system\/sockets.target.wants\/*udev*; \\\r\n     rm -f \/lib\/systemd\/system\/sockets.target.wants\/*initctl*; \\\r\n     rm -f \/lib\/systemd\/system\/basic.target.wants\/*;\\\r\n     rm -f \/lib\/systemd\/system\/anaconda.target.wants\/*;\r\n\r\n     VOLUME [ \"\/sys\/fs\/cgroup\" ]\r\n\r\n     CMD [\"\/usr\/sbin\/init\"]\r\n<\/code><\/pre>\n<h4>PostgreSQL\u955c\u50cf\u7684DOCKERFILE<\/h4>\n<p>\u5728CentOS_Postgresql12\u76ee\u5f55\u4e2d\u521b\u5efaDockerfile\u3002<\/p>\n<pre class=\"post-pre\"><code>     $ cd ..\/CentOS_Postgresql12\r\n     $ vi .\/Dockerfile \r\n<\/code><\/pre>\n<p>\u5c06\u4ee5\u4e0b\u5185\u5bb9\u8bb0\u5f55\u5e76\u4fdd\u5b58\u5230Dockerfile\u4e2d\u3002<\/p>\n<pre class=\"post-pre\"><code>    FROM gomadofu\/method2_csystemd:1\r\n\r\n    #CentOS-8\u306e\u5834\u5408\u306f\u4ee5\u4e0b\u3092\u4f7f\u3046\u3002\r\n    RUN dnf -y install https:\/\/download.postgresql.org\/pub\/repos\/yum\/reporpms\/EL-8-x86_64\/pgdg-redhat-repo-latest.noarch.rpm; \\\r\n    dnf -qy module disable postgresql; \\\r\n    dnf -y install postgresql12-server postgresql12 postgresql12-contrib; \\\r\n    dnf -y install passwd;\r\n\r\n    #CentOS-7\u306e\u5834\u5408\u306f\u4ee5\u4e0b\u3092\u4f7f\u3046\u3002\r\n    # RUN yum -y install https:\/\/download.postgresql.org\/pub\/repos\/yum\/reporpms\/EL-7-x86_64\/pgdg-redhat-repo-latest.noarch.rpm; \\\r\n    # yum -y install postgresql12-server postgresql12 postgresql12-contrib; \\\r\n    # yum -y install passwd;\r\n\r\n    COPY .\/postgresql-12-setup   \/usr\/pgsql-12\/bin\/postgresql-12-setup\r\n    RUN chmod +x \/usr\/pgsql-12\/bin\/postgresql-12-setup\r\n\r\n    RUN  PGSETUP_INITDB_OPTIONS=\"-E UTF8 --no-locale\" \/usr\/pgsql-12\/bin\/postgresql-12-setup initdb\r\n\r\n    COPY .\/*.conf \/var\/lib\/pgsql\/12\/data\/\r\n    COPY .\/setting_*.sh \/var\/lib\/pgsql\/\r\n\r\n    RUN chmod +x \/var\/lib\/pgsql\/setting_postgres*.sh; \\\r\n    chown -v postgres.postgres \/var\/lib\/pgsql\/12\/data\/postgresql.conf; \\\r\n    chown -v postgres.postgres \/var\/lib\/pgsql\/12\/data\/pg_hba.conf; \\\r\n    \/var\/lib\/pgsql\/setting_postgresql.sh;\r\n\r\n    EXPOSE 5432\r\n\r\n    RUN su -l postgres -c \"\/usr\/pgsql-12\/bin\/pg_ctl start\"; \\\r\n    su -l postgres -c \".\/setting_postgresqluser.sh\"; \\\r\n    su -l postgres -c \"\/usr\/pgsql-12\/bin\/pg_ctl stop\"; \\\r\n    systemctl enable postgresql-12.service;\r\n\r\n    CMD [\u201c\/usr\/sbin\/init\"]\r\n<\/code><\/pre>\n<h3>\u5bf92-3.initdb\u811a\u672c\u8fdb\u884c\u4fee\u6b63\u3002<\/h3>\n<p>\u5c06.\/CentOS_Postgresql12\/Postgresql-12-setup\u8fdb\u884c\u4fee\u6539\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ vi .\/Postgresql-12-setup\r\n<\/code><\/pre>\n<p>\u4fee\u6539\u4ee5\u4e0b\u90e8\u5206\u5e76\u4fdd\u5b58\u3002<\/p>\n<pre class=\"post-pre\"><code>   &lt;Postgresql-12-setup&gt;\r\n\r\n   [\u5909\u66f4\u524d]\r\n   PGDATA=`systemctl show -p Environment \"${SERVICE_NAME}.service\" |\r\n               sed 's\/^Environment=\/\/' | tr ' ' '\\n' |\r\n               sed -n 's\/^PGDATA=\/\/p' | tail -n 1`\r\n   if [ x\"$PGDATA\" = x ]; then\r\n      echo \"failed to find PGDATA setting in ${SERVICE_NAME}.service\"\r\n      exit 1\r\n   fi\r\n\r\n   [\u5909\u66f4\u5f8c]\r\n   PGDATA=\"\/var\/lib\/pgsql\/12\/data\/\"\r\n   #PGDATA=`systemctl show -p Environment \"${SERVICE_NAME}.service\" |\r\n   #                sed 's\/^Environment=\/\/' | tr ' ' '\\n' |\r\n   #                sed -n 's\/^PGDATA=\/\/p' | tail -n 1`\r\n   #if [ x\"$PGDATA\" = x ]; then\r\n   #    echo \"failed to find PGDATA setting in ${SERVICE_NAME}.service\"\r\n   #    exit 1\r\n   #fi\r\n<\/code><\/pre>\n<h3>2-4.\u6267\u884c\u6784\u5efa<\/h3>\n<p>\u521b\u5efa\u4e00\u4e2a\u652f\u6301systemctl\u547d\u4ee4\u7684\u955c\u50cf\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ cd .\/CentOS_Systems\r\n   $ docker build --rm -t gomadofu\/method2_csystemd:1 .\r\n<\/code><\/pre>\n<p>\u521b\u5efa\u4e00\u4e2a\u652f\u6301systemctl\u547d\u4ee4\u7684\u955c\u50cf\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ cd ..\/CentOS8_Postgresql12\r\n   $ docker build --rm -t gomadofu\/method2_cp12:1 .\r\n<\/code><\/pre>\n<h3>2-5. \u542f\u52a8\u5bb9\u5668\uff08\u8fdb\u884c\u64cd\u4f5c\u786e\u8ba4\uff09<\/h3>\n<p>\u4f7f\u7528\u521b\u5efa\u7684\u6620\u50cf\u6765\u542f\u52a8\u5bb9\u5668\u3002<\/p>\n<pre class=\"post-pre\"><code>   $ docker container run -d --privileged -v (\u30db\u30b9\u30c8OS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea):(\u30b3\u30f3\u30c6\u30caOS\u5185\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea) -p 10864:5432 --name='method2_cp12' gomadofu\/method2_cp12:1 \/sbin\/init\r\n<\/code><\/pre>\n<p>\u901a\u8fc7&#8221;1-7.\u52a8\u4f5c\u786e\u8ba4&#8221;\u548c&#8221;1-8.\u4ece\u4e3b\u673a\u64cd\u4f5c\u7cfb\u7edf\u8fdb\u884c\u8fde\u63a5\u786e\u8ba4&#8221;\u8fdb\u884c\u64cd\u4f5c\u548c\u8fde\u63a5\u786e\u8ba4\u6d4b\u8bd5\uff0c\u5982\u679c\u80fd\u591f\u8fde\u63a5\u6210\u529f\uff0c\u5219\u8868\u793a\u5b8c\u6210\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u8fd9\u662f\u5728CentOS7\/8\u4e0a\u521b\u5efaPostgreSQL12\u7684Docker\u955c\u50cf\u7684\u6b65\u9aa4\u8bb0\u5f55\u3002(\u7531\u4e8e\u5c1d\u8bd5\u521b\u5efaDocker [&hellip;]<\/p>\n","protected":false},"author":10,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-41954","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5728centos7-8postgresql12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8esql\u7ec3\u4e60\u7684docker\u5bb9\u5668\u955c\u50cf\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf\" \/>\n<meta property=\"og:description\" content=\"\u8fd9\u662f\u5728CentOS7\/8\u4e0a\u521b\u5efaPostgreSQL12\u7684Docker\u955c\u50cf\u7684\u6b65\u9aa4\u8bb0\u5f55\u3002(\u7531\u4e8e\u5c1d\u8bd5\u521b\u5efaDocker [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5728centos7-8postgresql12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8esql\u7ec3\u4e60\u7684docker\u5bb9\u5668\u955c\u50cf\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2024-03-04T12:50:57+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T01:26:09+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d49f337434c4406cb1699\/5-0.png\" \/>\n<meta name=\"author\" content=\"\u5b87, \u534e\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u5b87, \u534e\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"6 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/\",\"name\":\"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2024-03-04T12:50:57+00:00\",\"dateModified\":\"2024-04-30T01:26:09+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458\",\"name\":\"\u5b87, \u534e\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g\",\"caption\":\"\u5b87, \u534e\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5728centos7-8postgresql12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8esql\u7ec3\u4e60\u7684docker\u5bb9\u5668\u955c\u50cf\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf","og_description":"\u8fd9\u662f\u5728CentOS7\/8\u4e0a\u521b\u5efaPostgreSQL12\u7684Docker\u955c\u50cf\u7684\u6b65\u9aa4\u8bb0\u5f55\u3002(\u7531\u4e8e\u5c1d\u8bd5\u521b\u5efaDocker [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u6211\u5728centos7-8postgresql12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8esql\u7ec3\u4e60\u7684docker\u5bb9\u5668\u955c\u50cf\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2024-03-04T12:50:57+00:00","article_modified_time":"2024-04-30T01:26:09+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d49f337434c4406cb1699\/5-0.png"}],"author":"\u5b87, \u534e","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u5b87, \u534e","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"6 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/","name":"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2024-03-04T12:50:57+00:00","dateModified":"2024-04-30T01:26:09+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u6211\u5728CentOS7\/8+PostgreSQL12\u4e0a\u521b\u5efa\u4e86\u4e00\u4e2a\u7528\u4e8eSQL\u7ec3\u4e60\u7684Docker\u5bb9\u5668\u955c\u50cf"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/513018e4e121d3add1b7c5de8be21458","name":"\u5b87, \u534e","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/63cd45cbc05a35fc4ff7637a163c83c4962ef58d27472726c3a3e0c9c5194f0f?s=96&d=mm&r=g","caption":"\u5b87, \u534e"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yuhua\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e6%88%91%e5%9c%a8centos7-8postgresql12%e4%b8%8a%e5%88%9b%e5%bb%ba%e4%ba%86%e4%b8%80%e4%b8%aa%e7%94%a8%e4%ba%8esql%e7%bb%83%e4%b9%a0%e7%9a%84docker%e5%ae%b9%e5%99%a8%e9%95%9c%e5%83%8f%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41954","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/10"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=41954"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41954\/revisions"}],"predecessor-version":[{"id":91076,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/41954\/revisions\/91076"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=41954"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=41954"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=41954"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}