{"id":26437,"date":"2023-04-27T17:27:43","date_gmt":"2023-04-24T10:16:22","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/"},"modified":"2025-08-11T21:17:12","modified_gmt":"2025-08-11T13:17:12","slug":"dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/","title":{"rendered":"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7"},"content":{"rendered":"<p>\u516c\u5f0f Ubuntu\u30a4\u30e1\u30fc\u30b8\u306b PostgreSQL\u306a\u3069\u3092\u3064\u3081\u3053\u3093\u3067\u307f\u307e\u3059<\/p>\n<h2>\u8bf7\u53c2\u8003\u8be5\u9875\u3002docker docs \u516c\u5f0f\u30b5\u30a4\u30c8<br \/>\nhttps:\/\/matsuand.github.io\/docs.docker.jp.onthefly\/<\/p>\n<h2>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30d0\u30fc\u30b8\u30e7\u30f3Docker\u684c\u9762\u72484.6.1<br \/>\nUbuntu 22.04 LTS<br \/>\nPostgreSQL 15<br \/>\n.NET6<br \/>\n.NET7<\/p>\n<h2>Docker Desktop \u306e\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u9002\u7528\u4e8e Mac \u548c Windows \u7684 Docker \u5957\u4ef6\u5171\u4eab\u5e73\u53f0<\/p>\n<p>Windows\u306e\u307f WSL2 for x64<br \/>\nhttps:\/\/wslstorestorage.blob.core.windows.net\/wslblob\/wsl_update_x64.msi<\/p>\n<h2>\u8fdb\u884c\u7b2c\u4e00\u6b21\u52a8\u4f5c\u786e\u8ba4\u4ece\u547d\u4ee4\u884c\u8fdb\u884c\u64cd\u4f5c\u6d4b\u8bd5<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u516c\u5f0f\u30a4\u30e1\u30fc\u30b8\u3092\u53d6\u5f97<\/span>\r\ndocker pull hello-world\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u3092\u4f5c\u6210<\/span>\r\ndocker run <span class=\"nt\">-it<\/span> <span class=\"nt\">--name<\/span> hello-world hello-world\r\nHello from Docker!\r\nThis message shows that your installation appears to be working correctly.\r\n<span class=\"o\">(<\/span>\u4e2d\u7565<span class=\"o\">)<\/span>\r\n<\/code><\/pre>\n<h2>\u30b3\u30f3\u30c6\u30ca\u64cd\u4f5c<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u4e00\u89a7<\/span>\r\ndocker ps <span class=\"nt\">-a<\/span>\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u958b\u59cb<\/span>\r\ndocker start \u30b3\u30f3\u30c6\u30caID or \u30b3\u30f3\u30c6\u30ca\u540d\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u505c\u6b62<\/span>\r\ndocker stop \u30b3\u30f3\u30c6\u30caID or \u30b3\u30f3\u30c6\u30ca\u540d\r\n<\/code><\/pre>\n<h2>\u30a4\u30e1\u30fc\u30b8\u64cd\u4f5c<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30a4\u30e1\u30fc\u30b8\u4e00\u89a7<\/span>\r\ndocker images\r\n\r\n<span class=\"c\"># \u30a4\u30e1\u30fc\u30b8\u524a\u9664<\/span>\r\ndocker <span class=\"nb\">rm <\/span>\u30a4\u30e1\u30fc\u30b8\u540d[:\u30bf\u30b0]\r\n<\/code><\/pre>\n<h2>\u30a4\u30e1\u30fc\u30b8\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<br \/>\n\u57fa\u4e8e\u63d0\u4f9b\u7684\u516c\u5f0f\u56fe\u50cf\uff0c\u63cf\u8ff0\u6dfb\u52a0\u5e94\u7528\u7a0b\u5e8f\u548c\u8bbe\u7f6e\u3002<br \/>\n\u4ee5\u4e0b\u5047\u8bbe\u5728\/Users\/\u7528\u6237\u540d\/Docker\/Ubuntu\u76ee\u5f55\u4e0b\u521b\u5efa\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For Docker<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">FROM<\/span><span class=\"s\"> ubuntu:22.04<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For Ubuntu<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\">#\u30b7\u30a7\u30eb\u6307\u5b9a<\/span>\r\n<span class=\"k\">SHELL<\/span><span class=\"s\"> [\"\/usr\/bin\/bash\", \"-l\", \"-c\"]<\/span>\r\n\r\n<span class=\"c\">#\u521d\u56de\u306e\u30a2\u30c3\u30d7\u30c7\u30fc\u30c8\u3092\u5f37\u5236<\/span>\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt upgrade <span class=\"nt\">-y<\/span>\r\n\r\n<span class=\"c\">#\u6700\u4f4e\u9650\u306e\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u30c4\u30fc\u30eb<\/span>\r\n<span class=\"c\">#2\u56de\u76ee\u4ee5\u964d\u306eapt install\u3067\u3082\u6bce\u56deupdate\u3092\u3057\u3066\u3001docker\u306e\u5dee\u5206build\u306b\u3088\u308b\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u60aa\u3055\u3092\u56de\u907f\u3059\u308b<\/span>\r\n<span class=\"k\">RUN <\/span>apt-get update <span class=\"o\">&amp;&amp;<\/span> apt-get <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> ca-certificates curl dnsutils gnupg gnupg2 htop iputils-ping lsb-release net-tools sqlite3 vim wget lftp\r\n\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For PostgreSQL<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> TZ=Asia\/Tokyo<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> LANG=ja_JP.UTF-8<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> LANGUAGE=ja_JP:ja<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> LC_ALL=ja_JP.UTF-8<\/span>\r\n\r\n\r\n<span class=\"c\">#\u7121\u4eba\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u5316<\/span>\r\n<span class=\"k\">ARG<\/span><span class=\"s\"> DEBIAN_FRONTEND=noninteractive<\/span>\r\n<span class=\"k\">RUN <\/span>apt-get update <span class=\"o\">&amp;&amp;<\/span> apt-get <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> locales-all\r\n<span class=\"k\">RUN <\/span>curl https:\/\/www.postgresql.org\/media\/keys\/ACCC4CF8.asc | gpg <span class=\"nt\">--dearmor<\/span> | <span class=\"nb\">tee<\/span> \/etc\/apt\/trusted.gpg.d\/apt.postgresql.org.gpg <span class=\"o\">&gt;<\/span>\/dev\/null\r\n<span class=\"k\">RUN <\/span>sh <span class=\"nt\">-c<\/span> <span class=\"s1\">'echo \"deb http:\/\/apt.postgresql.org\/pub\/repos\/apt $(lsb_release -cs)-pgdg main\" &gt; \/etc\/apt\/sources.list.d\/pgdg.list'<\/span>\r\n<span class=\"k\">RUN <\/span>apt-get update <span class=\"o\">&amp;&amp;<\/span> apt-get <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> postgresql-15\r\n\r\n<span class=\"c\">#\u521d\u671f\u8a2d\u5b9a<\/span>\r\n<span class=\"k\">USER<\/span><span class=\"s\"> postgres<\/span>\r\n<span class=\"k\">RUN <\/span>\/etc\/init.d\/postgresql start <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-c<\/span> <span class=\"s2\">\"alter user postgres with encrypted password 'postgres'\"<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-c<\/span> <span class=\"s2\">\"create user docker with password 'docker' superuser;\"<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-c<\/span> <span class=\"s2\">\"create database docker owner docker;\"<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-d<\/span> docker <span class=\"nt\">-c<\/span> <span class=\"s2\">\"create schema authorization docker;\"<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-c<\/span> <span class=\"s2\">\"create role readonly with login password 'readonly';\"<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"se\">\\\r\n<\/span>        psql <span class=\"nt\">-c<\/span> <span class=\"s2\">\"grant pg_read_all_data to readonly;\"<\/span>\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">echo<\/span> <span class=\"s2\">\"host all all 0.0.0.0\/0 md5\"<\/span> <span class=\"o\">&gt;&gt;<\/span> \/etc\/postgresql\/15\/main\/pg_hba.conf\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">echo<\/span> <span class=\"s2\">\"listen_addresses='*'\"<\/span> <span class=\"o\">&gt;&gt;<\/span> \/etc\/postgresql\/15\/main\/postgresql.conf\r\n<span class=\"k\">USER<\/span><span class=\"s\"> root<\/span>\r\n\r\n<span class=\"c\">#\u30dd\u30fc\u30c8\u89e3\u653e<\/span>\r\n<span class=\"k\">EXPOSE<\/span><span class=\"s\"> 5432<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For .NET 6<\/span>\r\n<span class=\"c\"># Ubuntu22.04\u304b\u3089\u516c\u5f0f\u30ec\u30dd\u30b8\u30c8\u30ea\u7d4c\u7531\u3067\u306e\u53d6\u5f97\u304c\u53ef\u80fd<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># RUN apt-get update &amp;&amp; apt-get install -y dotnet6<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For .NET 7<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">RUN <\/span>wget https:\/\/packages.microsoft.com\/config\/ubuntu\/22.04\/packages-microsoft-prod.deb <span class=\"nt\">-O<\/span> packages-microsoft-prod.deb\r\n<span class=\"k\">RUN <\/span>dpkg <span class=\"nt\">-i<\/span> packages-microsoft-prod.deb\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">rm <\/span>packages-microsoft-prod.deb\r\n<span class=\"c\">#RUN apt-get update &amp;&amp; apt-get install -y apt-transport-https<\/span>\r\n<span class=\"k\">RUN <\/span>apt-get update <span class=\"o\">&amp;&amp;<\/span> apt-get <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> dotnet-sdk-7.0 aspnetcore-runtime-7.0\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For OpenJDK<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> TZ=Asia\/Tokyo<\/span>\r\n\r\n<span class=\"c\">#\u7121\u4eba\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u5316<\/span>\r\n<span class=\"k\">ARG<\/span><span class=\"s\"> DEBIAN_FRONTEND=noninteractive<\/span>\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> openjdk-17-jdk\r\n\r\n<span class=\"c\">#\u74b0\u5883\u5909\u6570<\/span>\r\n<span class=\"c\">#\/etc\/environment\u306b\u66f8\u304d\u8fbc\u3093\u3067\u3082\u30ed\u30b0\u30a4\u30f3\u6642\u306bsource\u3057\u3066\u306a\u3044\u305f\u3081\u3001Dockerfile\u3067\u5909\u6570\u30bb\u30c3\u30c8\u3059\u308b<\/span>\r\n<span class=\"c\">#RUN echo \"JAVA_HOME=\\\"\/usr\/lib\/jvm\/java-17-openjdk-amd64\\\"\" &gt;&gt; \/etc\/environment<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> JAVA_HOME=\/usr\/lib\/jvm\/java-17-openjdk-amd64<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For TomCat<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> tomcat9 tomcat9-admin\r\n\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> CATALINA_HOME=\/usr\/share\/tomcat9<\/span>\r\n<span class=\"k\">ENV<\/span><span class=\"s\"> CATALINA_BASE=\/var\/lib\/tomcat9<\/span>\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/mnt\/tomcat9\/var\/lib\/tomcat9\/conf\/web.xml \/var\/lib\/tomcat9\/conf<\/span>\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/mnt\/tomcat9\/var\/lib\/tomcat9\/webapps\/ROOT\/index.txt \/var\/lib\/tomcat9\/webapps\/ROOT<\/span>\r\n\r\n<span class=\"c\">#\u30dd\u30fc\u30c8\u89e3\u653e<\/span>\r\n<span class=\"k\">EXPOSE<\/span><span class=\"s\"> 8080<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For Nginx<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> ubuntu-keyring\r\n<span class=\"k\">RUN <\/span>curl https:\/\/nginx.org\/keys\/nginx_signing.key | gpg <span class=\"nt\">--dearmor<\/span> | <span class=\"nb\">tee<\/span> \/usr\/share\/keyrings\/nginx-archive-keyring.gpg <span class=\"o\">&gt;<\/span>\/dev\/null\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">echo<\/span> <span class=\"s2\">\"deb [signed-by=\/usr\/share\/keyrings\/nginx-archive-keyring.gpg] http:\/\/nginx.org\/packages\/ubuntu <\/span><span class=\"sb\">`<\/span>lsb_release <span class=\"nt\">-cs<\/span><span class=\"sb\">`<\/span><span class=\"s2\"> nginx\"<\/span> | <span class=\"nb\">tee<\/span> \/etc\/apt\/sources.list.d\/nginx.list\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> nginx fcgiwrap spawn-fcgi\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/mnt\/nginx\/etc\/nginx\/nginx.conf \/etc\/nginx<\/span>\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/mnt\/nginx\/usr\/share\/nginx\/html\/* \/usr\/share\/nginx\/html<\/span>\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">chmod <\/span>755 \/usr\/share\/nginx\/html\/index.sh\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/mnt\/fcgiwrap\/etc\/init.d\/fcgiwrap \/etc\/init.d<\/span>\r\n\r\n<span class=\"c\">#\u30dd\u30fc\u30c8\u89e3\u653e<\/span>\r\n<span class=\"k\">EXPOSE<\/span><span class=\"s\"> 8000<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For Node.js<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">RUN <\/span>curl <span class=\"nt\">-fsSL<\/span> https:\/\/deb.nodesource.com\/setup_16.x | bash -\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> nodejs\r\n\r\n<span class=\"c\">#\u30dd\u30fc\u30c8\u89e3\u653e<\/span>\r\n<span class=\"k\">EXPOSE<\/span><span class=\"s\"> 8888<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For MongoDB<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"k\">RUN <\/span>wget <span class=\"nt\">-qO<\/span> - https:\/\/www.mongodb.org\/static\/pgp\/server-5.0.asc | apt-key add -\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">echo<\/span> <span class=\"s2\">\"deb [ arch=amd64,arm64 ] https:\/\/repo.mongodb.org\/apt\/ubuntu focal\/mongodb-org\/5.0 multiverse\"<\/span> | <span class=\"nb\">tee<\/span> \/etc\/apt\/sources.list.d\/mongodb-org-5.0.list\r\n<span class=\"k\">RUN <\/span>apt update <span class=\"o\">&amp;&amp;<\/span> apt <span class=\"nb\">install<\/span> <span class=\"nt\">-y<\/span> mongodb-org\r\n<span class=\"k\">EXPOSE<\/span><span class=\"s\"> 27017<\/span>\r\n\r\n\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\"># For Docker<\/span>\r\n<span class=\"c\">#---------------------------------<\/span>\r\n<span class=\"c\">#\u30b3\u30f3\u30c6\u30ca\u8d77\u52d5\u6642\u306b\u5404\u30b5\u30fc\u30d3\u30b9\u30fb\u30d7\u30ed\u30bb\u30b9\u3092\u8d77\u52d5<\/span>\r\n<span class=\"k\">COPY<\/span><span class=\"s\"> .\/startup.sh \/startup.sh<\/span>\r\n<span class=\"k\">RUN <\/span><span class=\"nb\">chmod <\/span>744 \/startup.sh\r\n<span class=\"k\">STOPSIGNAL<\/span><span class=\"s\"> SIGINT<\/span>\r\n<span class=\"k\">ENTRYPOINT<\/span><span class=\"s\"> \/startup.sh<\/span>\r\n<\/code><\/pre>\n<p>\u4ee5 startup.sh \u7684\u540d\u79f0\u521b\u5efa\u542f\u52a8\u548c\u5173\u95ed\u811a\u672c\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\">#!\/bin\/sh<\/span>\r\n\r\n<span class=\"c\">#\u7d42\u4e86\u51e6\u7406<\/span>\r\nhandle<span class=\"o\">(){<\/span>\r\n  \/etc\/init.d\/fcgiwrap stop\r\n  \/etc\/init.d\/ngix stop\r\n  \/etc\/init.d\/postgresql stop\r\n  <span class=\"nb\">exit <\/span>0\r\n<span class=\"o\">}<\/span>\r\n<span class=\"nb\">trap <\/span>handle TERM INT\r\n\r\n<span class=\"c\">#\u8d77\u52d5\u51e6\u7406<\/span>\r\n\/usr\/libexec\/tomcat9\/tomcat-start.sh &amp;\r\n\/usr\/bin\/node \/mnt\/bind\/nodejs\/webserver.js &amp;\r\n\/etc\/init.d\/fcgiwrap start\r\n\/etc\/init.d\/nginx start\r\n\/etc\/init.d\/postgresql start\r\n\/bin\/bash\r\n<\/code><\/pre>\n<h2>\u5728\u4e2d\u56fd\u6267\u884c\u5f62\u8c61\u5efa\u8bbe<\/p>\n<pre class=\"post-pre\"><code>docker build <span class=\"nt\">-t<\/span> \u30a4\u30e1\u30fc\u30b8\u540d[:\u30bf\u30b0] <span class=\"nb\">.<\/span>\r\n<\/code><\/pre>\n<h2>\u30b3\u30f3\u30c6\u30ca\u4f5c\u6210<\/p>\n<pre class=\"post-pre\"><code>docker run <span class=\"nt\">-it<\/span> <span class=\"nt\">-d<\/span>\r\n  <span class=\"nt\">-p<\/span> \u30db\u30b9\u30c8\u30dd\u30fc\u30c81:\u30b3\u30f3\u30c6\u30ca\u30dd\u30fc\u30c81\r\n  <span class=\"nt\">-p<\/span> \u30db\u30b9\u30c8\u30dd\u30fc\u30c82:\u30b3\u30f3\u30c6\u30ca\u30dd\u30fc\u30c82\r\n  <span class=\"nt\">-p<\/span> \u30db\u30b9\u30c8\u30dd\u30fc\u30c83:\u30b3\u30f3\u30c6\u30ca\u30dd\u30fc\u30c83\r\n  <span class=\"nt\">--mount<\/span> <span class=\"nb\">type<\/span><span class=\"o\">=<\/span><span class=\"nb\">bind<\/span>,source<span class=\"o\">=<\/span>\/Users\/\u30e6\u30fc\u30b6\u540d\/Docker\/Ubuntu\/mnt,target<span class=\"o\">=<\/span>\/mnt\r\n  <span class=\"nt\">--name<\/span> \u30b3\u30f3\u30c6\u30ca\u540d\r\n  \u30a4\u30e1\u30fc\u30b8\u540d:\u30bf\u30b0\r\n<\/code><\/pre>\n<h2>\u786e\u8ba4\u52a8\u4f5c\u8fde\u63a5\u5230\u8fd0\u884c\u5728Docker\u4e0a\u7684Ubuntu\uff0c\u5e76\u8fdb\u4e00\u6b65\u8fde\u63a5\u5230PostgreSQL\u4ee5\u786e\u8ba4\u7248\u672c\u4fe1\u606f\u7b49\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u4e00\u89a7<\/span>\r\ndocker ps <span class=\"nt\">-a<\/span>\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u60c5\u5831<\/span>\r\ndocker inspect \u30b3\u30f3\u30c6\u30ca\u540d\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u60c5\u5831 (\u30de\u30a6\u30f3\u30c8\u60c5\u5831)<\/span>\r\ndocker inspect <span class=\"nt\">--format<\/span><span class=\"o\">=<\/span><span class=\"s1\">'{{.Mounts}}'<\/span> \u30b3\u30f3\u30c6\u30ca\u540d\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u60c5\u5831 (IP\u60c5\u5831)<\/span>\r\ndocker inspect <span class=\"nt\">--format<\/span><span class=\"o\">=<\/span><span class=\"s1\">'{{.NetworkSettings.IPAddress}}'<\/span> \u30b3\u30f3\u30c6\u30ca\u540d\r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u60c5\u5831 (\u30dd\u30fc\u30c8\u30d5\u30a9\u30fc\u30ef\u30fc\u30c9\u60c5\u5831)<\/span>\r\ndocker inspect <span class=\"nt\">--format<\/span><span class=\"o\">=<\/span><span class=\"s1\">'{{.NetworkSettings.Ports}}'<\/span> \u30b3\u30f3\u30c6\u30ca\u540d \r\n\r\n<span class=\"c\"># \u30b3\u30f3\u30c6\u30ca\u30ed\u30b0<\/span>\r\ndocker logs \u30b3\u30f3\u30c6\u30ca\u540d\r\n\r\n<span class=\"c\"># Ubuntu \u63a5\u7d9a<\/span>\r\ndocker <span class=\"nb\">exec<\/span> <span class=\"nt\">-it<\/span> \u30b3\u30f3\u30c6\u30ca\u540d bash\r\n\r\n<span class=\"c\"># PostgreSQL \u63a5\u7d9a<\/span>\r\npsql <span class=\"nt\">-h<\/span> 127.0.0.1 <span class=\"nt\">-U<\/span> docker\r\nPassword <span class=\"k\">for <\/span>user docker: docker\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"c1\">-- \u3053\u3053\u304b\u3089 PostgreSQL \u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9<\/span>\r\n<span class=\"c1\">-- \u30d0\u30fc\u30b8\u30e7\u30f3\u60c5\u5831<\/span>\r\n<span class=\"k\">select<\/span> <span class=\"k\">version<\/span><span class=\"p\">();<\/span>\r\n<span class=\"k\">version<\/span>                                                              \r\n<span class=\"c1\">------------------------------------------------------------------<\/span>\r\n<span class=\"n\">PostgreSQL<\/span> <span class=\"mi\">14<\/span><span class=\"p\">.<\/span><span class=\"mi\">2<\/span> <span class=\"p\">(<\/span><span class=\"n\">Ubuntu<\/span> <span class=\"mi\">14<\/span><span class=\"p\">.<\/span><span class=\"mi\">2<\/span><span class=\"o\">-<\/span><span class=\"mi\">1<\/span><span class=\"p\">.<\/span><span class=\"n\">pgdg20<\/span><span class=\"p\">.<\/span><span class=\"mi\">04<\/span><span class=\"o\">+<\/span><span class=\"mi\">1<\/span><span class=\"p\">)<\/span> <span class=\"k\">on<\/span> <span class=\"n\">x86_64<\/span><span class=\"o\">-<\/span><span class=\"n\">pc<\/span><span class=\"o\">-<\/span><span class=\"n\">linux<\/span><span class=\"o\">-<\/span><span class=\"n\">gnu<\/span>\r\n<span class=\"p\">(<\/span><span class=\"mi\">1<\/span> <span class=\"k\">row<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\">-- \u73fe\u5728\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9<\/span>\r\n<span class=\"k\">select<\/span> <span class=\"n\">current_database<\/span><span class=\"p\">();<\/span>\r\n<span class=\"n\">current_database<\/span> \r\n<span class=\"c1\">------------------<\/span>\r\n<span class=\"n\">docker<\/span>\r\n<span class=\"p\">(<\/span><span class=\"mi\">1<\/span> <span class=\"k\">row<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\">-- \u73fe\u5728\u306e\u30b9\u30ad\u30fc\u30de<\/span>\r\n<span class=\"k\">select<\/span> <span class=\"n\">current_schema<\/span><span class=\"p\">;<\/span>\r\n<span class=\"n\">current_schema<\/span> \r\n<span class=\"c1\">----------------<\/span>\r\n<span class=\"n\">docker<\/span>\r\n<span class=\"p\">(<\/span><span class=\"mi\">1<\/span> <span class=\"k\">row<\/span><span class=\"p\">)<\/span>\r\n\r\n<span class=\"c1\">-- \u7d42\u4e86<\/span>\r\n<span class=\"err\">\\<\/span><span class=\"n\">q<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"nt\">--<\/span> \u3053\u3053\u304b\u3089 \/bin\/bash\r\n<span class=\"nt\">--<\/span> \u7d42\u4e86\r\n<span class=\"nb\">exit<\/span>\r\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u516c\u5f0f Ubuntu\u30a4\u30e1\u30fc\u30b8\u306b PostgreSQL\u306a\u3069\u3092\u3064\u3081\u3053\u3093\u3067\u307f\u307e\u3059 \u8bf7\u53c2\u8003\u8be5\u9875\u3002docker docs  [&hellip;]<\/p>\n","protected":false},"author":7,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[227],"class_list":["post-26437","post","type-post","status-publish","format-standard","hentry","category-uncategorized","tag-227"],"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>Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7 - Blog - Silicon Cloud<\/title>\n<meta name=\"description\" content=\"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0\" \/>\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\/dockerubuntupostgresql-\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7-4\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\" \/>\n<meta property=\"og:description\" content=\"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7-4\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-04-24T10:16:22+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-08-11T13:17:12+00:00\" \/>\n<meta name=\"author\" content=\"\u79d1, \u9896\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u79d1, \u9896\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 \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\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/\",\"name\":\"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-04-24T10:16:22+00:00\",\"dateModified\":\"2025-08-11T13:17:12+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e\"},\"description\":\"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0\",\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\"}]},{\"@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\/8ca01ba7f7362ad4edb7da206a12f29e\",\"name\":\"\u79d1, \u9896\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g\",\"caption\":\"\u79d1, \u9896\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keying\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7 - Blog - Silicon Cloud","description":"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0","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\/dockerubuntupostgresql-\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7-4\/","og_locale":"zh_CN","og_type":"article","og_title":"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7","og_description":"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7-4\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-04-24T10:16:22+00:00","article_modified_time":"2025-08-11T13:17:12+00:00","author":"\u79d1, \u9896","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u79d1, \u9896","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"1 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/","name":"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-04-24T10:16:22+00:00","dateModified":"2025-08-11T13:17:12+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/8ca01ba7f7362ad4edb7da206a12f29e"},"description":"\u5173\u4e8eDocker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u7684\u6280\u672f\u6587\u7ae0","breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"Docker+Ubuntu+PostgreSQL \u30bb\u30c3\u30c8\u30a2\u30c3\u30d7"}]},{"@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\/8ca01ba7f7362ad4edb7da206a12f29e","name":"\u79d1, \u9896","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/8a6fb3cc7ba2f69d2189ba532aec4633ea7ed75ac0af162ec367cb3abc0fb2af?s=96&d=mm&r=g","caption":"\u79d1, \u9896"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keying\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/dockerubuntupostgresql-%e3%82%bb%e3%83%83%e3%83%88%e3%82%a2%e3%83%83%e3%83%97-4\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/26437","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\/7"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=26437"}],"version-history":[{"count":3,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/26437\/revisions"}],"predecessor-version":[{"id":110975,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/26437\/revisions\/110975"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=26437"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=26437"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=26437"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}