❶ docker中容器有必要掛載到主機上嗎存儲
例如docker run -it -v /data --name container1 busybox ); 和掛載到主機(例如docker run -it --name container1 -v /path/on/host:/datavol busybox )但是為了使容量在容器重啟甚至容器交換(舊容器被刪除,創build/啟動新容器)中保持不變,這兩種方法都不會將卷掛載到主機上嗎? 換句話說,如果我沒有通過「簡單安裝方法」明確地掛載到主機,那麼卷的實際安裝位置在哪裡? 而且這個位置如何在容器交換中生存呢?而且,在這兩種情況下,我都假定卷只是給定主機的本地卷,並且如果有一個Swarm或群集運行在多個主機上,則無法使用這些命令,以便在不同主機上運行的容器可以訪問這些卷,是嗎? (而且我猜這是Data Volume Containers發揮的作用,對吧?)提前致謝!這兩種方法都不能將卷掛載到主機上?是的,這兩種方法都基於容器生命周期中保存的主機目錄。使用這些命令獲取更多信息:docker volume ls docker volume inspect <volume-id> # and docker inspect <container-id>(方法1)實際安裝量在哪裡?做這個:docker inspect <container-id>你的答案在「來源」中:"Mounts": [ { "Type": "volume", "Name": "", "Source": "/var/lib/docker/volumes//_data", "Destination": "/data", "Driver": "local", "Mode": "", "RW": true, "Propagation": "" } ],請注意,如果您在OSX或Windows中,則該Source指的是運行docker的VM內部的本地目錄。而且這個位置如何在容器交換中生存呢?他們生存,因為他們是基於主機的本地目錄(他們是卷,因此它們存在)。如果在多個主機上運行Swarm或群集,則無法使用這些命令,以便運行在不同主機上的容器可以訪問這些卷,是的?您對簡單的卷configuration是正確的。 這是docker變得棘手,持久的地方。 您可以在主機文件系統級別實現共享目錄,然後將其作為卷裝載到容器中,以便跨群集主機獲取共享卷。https://docs.docker.com/engine/tutorials/dockervolumes/#mount-a-shared-storage-volume-as-a-data-volume使用php在shell中運行docker運行或重新啟動PostgreSQL映像後,Docker容器立即退出在CentOS7上暴露Docker Remote API v1.22在Docker上的terminal上安裝Gambit綁定的文件夾的內容不可用Docker nginx錯誤在安assembly置文件Docker(帶有SYSTEMCTL的CentOS 7):無法安裝tmpfs&cgroup如何使用rabbitmq docker撰寫yml文件來構builddocker鏡像?Docker-Compose找不到新的節點模塊MongoDB使用具有持久存儲問題的docker分片群集在Docker中將「named volume」掛載為非root用戶
❷ 如何在PHP中開啟GD庫支持
開啟GD庫支持有以下幾種方法 檢測GD庫是否安裝命令 php5 -m | grep -i gd 或者 php -i | grep -i --color gd如未安裝GD庫,則為伺服器安裝,方法如下 如果是源碼安裝,則加入參數 --with-gd 如果是debian系的linux系統,用apt-get安裝,如下 apt-get install php5-gd 如果是CentOS系的系統,用yum安裝,如下 yum install php-gd 如果是suse系的linux系統,用yast安裝,如下 yast -i php5_gd 如果嫌這個世界不夠蛋疼呢,可以在原先編譯PHP不支持GD的情況下附加 先下zlib源碼,libpng源碼,gd源碼 解壓後到源碼目錄 zlib目錄 ./configure --prefix=/usr/local/zlib make ; make install make clean libpng目錄 cp scripts/makefile.linux ./makefile ./configure --prefix=/usr/local/libpng make ; make install make clean gd目錄 ./configure --prefix=/usr/local/libgd --with-png=/usr/local/libpng make ; make install make clean 最後在php.ini中,搜到[gd]後,在下面加一行 extension=/usr/local/libgdgd.so 然後重啟php服務,如果不行,試試reboot 所以如果是源碼安裝,最好還是在編譯PHP的時候加參數--with-gd Windows下開啟PHP的GD庫支持 找到php.ini,打開內容,找到: ;extension=php_gd2.dll 把最前面的分號「;」去掉,再保存即可,如果本來就沒有分號,那就是已經開啟了。
❸ docker容器內怎麼連接外部的mysql
推薦使用Dockerfile方式。
服務的管理使用的是supervisord, 因為dockerfile里只會有一個cmd生效,如果我想通過ssh去管理容器還要有mysql服務的啟動起來 cmd的方式就無法實現,當然容器不需要以sshd的方式去管理,這些也都是看自己怎麼去使用,比如說我想備份容器里的數據 我完全可以使用 –volumes-from <容器name> , 重啟使用 docker restart <容器id>, 我個人也是使用ssh習慣了 所以依賴的鏡像把ssh服務栽進去了。
# docker 版本:
復制代碼
代碼如下:
[root@private_network mysql]# docker version
Client version: 1.6.0-rc5
Client API version: 1.18
Go version (client): go1.4.2
Git commit (client): fc4825d
OS/Arch (client): linux/amd64
Server version: 1.6.0-rc5
Server API version: 1.18
Go version (server): go1.4.2
Git commit (server): fc4825d
OS/Arch (server): linux/amd64[/code]
# 目錄結構
復制代碼
代碼如下:
mysql/
|-- cmake-3.2.2.tar.gz
|-- create_mysql_user.sh # mysql用戶初始化腳本
|-- Dockerfile
|-- install_mysql-5.6.24.sh # mysql服務安裝腳本
|-- my.cnf # mysql服務配置文件
|-- mysql-5.6.24.tar.gz
`-- supervisord.conf # 服務管理工具配置文件
# Dockerfile
復制代碼
代碼如下:
# FROM: 依賴的鏡像
FROM ted1993/mysql:5.6.24
#MAINTAINER: 個人信息
MAINTAINER xuqiangqiang "[email protected]"
# RUN: 執行命令
RUN yum -y install tar gcc-c++ supervisor ncurses-devel libtool bison bison-devel pwgen
RUN mkdir -p /var/log/supervisor
# ADD: 添加本地文件到容器中,如果是壓縮包會在目標目錄進行自動解壓,如果只想添加文件可以使用 COPY命令
ADD ./supervisord.conf /etc/supervisord.conf
ADD ./cmake-3.2.2.tar.gz /root/tools/
ADD ./mysql-5.6.24.tar.gz /root/tools/
ADD ./install_mysql-5.6.24.sh /root/tools/
ADD ./create_mysql_user.sh /create_mysql_user.sh
# WORKDIR: 當前的工作目錄
WORKDIR /root/tools/
RUN sh install_mysql-5.6.24.sh
ADD ./my.cnf /data/server/mysql-5.6.24/etc/my.cnf
RUN rm -rf /root/tools/mysql-5.6.24
RUN rm -rf /root/tools/mysql-5.6.24.tar.gz
RUN rm -rf /root/tools/cmake-3.2.2
RUN rm -rf /root/tools/cmake-3.2.2.tar.gz
# EXPOSE: 公開的埠,會暴露在外的埠
EXPOSE 22 3306
# CMD: 容器啟動執行的命令 一個dockerfile只有一個cmd生效。
CMD ["/usr/bin/supervisord"]
# supervisord.conf 服務管理工具通過supervisord管理服務
復制代碼
代碼如下:
[supervisord]
nodaemon=true
[program:mysqld]
command=/etc/init.d/mysqld start
numprocs=1
autostart=true
autorestart=true
[program:sshd]
command=/usr/sbin/sshd -D
numprocs=1
autostart=true
autorestart=true
# install_mysql-5.6.24.sh
復制代碼
代碼如下:
#!/bin/bash
grep "^mysql:" /etc/passwd &> /dev/null || groupadd mysql && useradd -g mysql -s /sbin/nologin mysql
if [ ! -d cmake-3.2.2 ];then
tar xzvf cmake-3.2.2.tar.gz
fi
cd cmake-3.2.2
./bootstrap && gmake && gmake install && cd ..
if [ ! -d mysql-5.6.24 ];then
tar xzf mysql-5.6.24.tar.gz
fi
cd mysql-5.6.24
cmake \
-DCMAKE_INSTALL_PREFIX=/data/server/mysql-5.6.24 \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DMYSQL_DATADIR=/data/mysql-5.6.24/ \
-DSYSCONFDIR=/data/server/mysql-5.6.24/etc/ \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_EXTRA_CHARSETS=complex \
-DENABLED_LOCAL_INFILE=1 \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_unicode_ci \
-DWITH_DEBUG=0
CPU_NUM=$(cat /proc/cpuinfo | grep processor | wc -l)
if [ $CPU_NUM -gt 1 ];then
make -j$CPU_NUM
else
make
fi
make install
echo "PATH=\$PATH:/data/server/mysql/bin" >> /etc/profile && . /etc/profile
ln -s /data/server/mysql-5.6.24/ /data/server/mysql
rm -rf /etc/my.cnf
mkdir -p /data/server/mysql-5.6.24/etc/
mkdir -p /data/server/mysql/data/
mkdir -p /data/log/mysql/
chown -R mysql:mysql /data/server/mysql/
chown -R mysql:mysql /data/server/mysql/data/
chown -R mysql:mysql /data/log/mysql
\cp -f /data/server/mysql/support-files/mysql.server /etc/init.d/mysqld
sed -i 's#^basedir=$#basedir=/data/server/mysql#' /etc/init.d/mysqld
sed -i 's#^datadir=$#datadir=/data/server/mysql/data#' /etc/init.d/mysqld
chmod 755 /etc/init.d/mysqld
/data/server/mysql/scripts/mysql_install_db --datadir=/data/server/mysql/data/ --basedir=/data/server/mysql --user=mysql
# create_mysql_user.sh
復制代碼
代碼如下:
#!/bin/bash
/data/server/mysql/bin/mysqld_safe >> /dev/null 2>&1 &
RET=1
while [[ RET -ne 0 ]]; do
echo "=> Waiting for confirmation of MySQL service startup"
sleep 5
/data/server/mysql/bin/mysql -uroot -e "status" > /dev/null 2>&1
RET=$?
done
echo "============================MYSQL_PASS_INFO=============================== "
echo ""
PASS_ROOT=${MYSQL_PASS:-$(pwgen -s 8 1)}
PASS_DBA=${MYSQL_PASS:-$(pwgen -s 8 1)}
echo ""
echo "=> Creating MySQL root user with ${PASS_ROOT} password"
echo "=> Creating MySQL dba user with ${PASS_DBA} password"
echo ""
/data/server/mysql/bin/mysql -uroot -e "grant all privileges on *.* to 'dba'@'%' identified by '${PASS_DBA}'";
/data/server/mysql/bin/mysql -uroot -e "update mysql.user set password=PASSWORD('${PASS_ROOT}') where user='root' and host='localhost'";
echo ""
echo "===================================END====================================="
echo ""
echo "=> Done!"
echo ""
echo ""
echo "==============================REMOTE_MYSQL_PASSWORD====================="
echo "You can now connect to this MySQL Server using:"
echo ""
echo " mysql -udba -p${PASS_DBA} -h<host> -P<port>"
echo ""
echo "Please remember to change the above password as soon as possible!"
echo "MySQL user 'root' has no password but only allows local connections"
echo "========================================================================"
# 通過docker build命令提交鏡像
復制代碼
代碼如下:
docker build -t ted1993/mysql:5.6.24 . # 注意最後面有一個"."
# 使用docker images 命令查看鏡像
復制代碼
代碼如下:
[root@private_network mysql]# docker images
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
ted1993/mysql 5.6.24 d3ed9c578f4c 5 days ago 902.8 MB
# 使用docker run 命令啟動容器 -P 使用隨機埠映射容器埠 -p 3306:3306 使用指定埠
復制代碼
代碼如下:
docker run -d -P ted1993/mysql:5.6.24
# 使用docker ps 命令查看運行容器id
復制代碼
代碼如下:
[root@private_network mysql]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ab622592bf1e mysql:5.6.24 "/usr/bin/supervisor 3 days ago Up 3 days 0.0.0.0:5000->22/tcp, 0.0.0.0:5001->3306/tcp jolly_swartz
# 使用docker commit 提交新的鏡像
docker commit ab622592bf1e ted1993/mysql:2015-06-02[/code]
Docker使用Link在容器之間建立連接
在使用Docker的時候我們會常常碰到這么一種應用,就是我需要兩個或多個容器,其中某些容器需要使用另外一些容器提供的服務。比如這么一種情況:我們需要一個容器來提供mysql的資料庫服務,而另外兩個容器作為客戶端來連接使用mysql資料庫服務。下面我們就來看看Docker是怎樣通過Link來實現這種功能的。
這里我們首先創建兩個容器image,一個用來模擬mysql資料庫,另外一個使用mysql的client來模擬一些使用mysql服務的應用,這種應用可以是任何php,python,java等的應用。
先創建一個mysql_server目錄並在其下創建一個Dockerfile文件,內容如下
復制代碼
代碼如下:
FROM centos:centos6
MAINTAINER Fanbin Kong "[email protected]"
RUN yum install -y mysql-server mysql
RUN /etc/init.d/mysqld start &&\
mysql -e "grant all privileges on *.* to 'root'@'%' identified by 'letmein';"&&\
mysql -e "grant all privileges on *.* to 'root'@'localhost' identified by 'letmein';"&&\
mysql -u root -pletmein -e "show databases;"
EXPOSE 3306
CMD ["/usr/bin/mysqld_safe"]
然後根據Dockerfile來創建image
復制代碼
代碼如下:
sudo docker build -t kongxx/mysql_server .
創建一個mysql_client目錄並在其下創建一個Dockerfile文件,內容如下
復制代碼
代碼如下:
FROM centos:centos6
MAINTAINER Fanbin Kong "[email protected]"
RUN yum install -y mysql
然後根據Dockerfile來創建image
復制代碼
代碼如下:
sudo docker build -t kongxx/mysql_client .
創建完image之後,我們可以使用下面命令來查看結果
復制代碼
代碼如下:
$ sudo docker images | grep kongxx
kongxx/mysql_client latest aa31f22f6fc5 2 hours ago 303.7 MB
kongxx/mysql_server latest 3b9b08c8dda4 2 hours ago 353.3 MB
第二步是根據image來創建我們的應用場景
首先創建提供mysql資料庫服務的容器
復制代碼
代碼如下:
sudo docker run --name=mysql_server -d -P kongxx/mysql_server
分別創建兩個使用上一步創建出來mysql資料庫服務的容器
第一個應用容器
復制代碼
代碼如下:
sudo docker run --name=mysql_client1 --link=mysql_server:db -t -i kongxx/mysql_client /usr/bin/mysql -h db -u root -pletmein
第二個應用容器
復制代碼
代碼如下:
sudo docker run --name=mysql_client2 --link=mysql_server:db -t -i kongxx/mysql_client /usr/bin/mysql -h db -u root -pletmein
這里需要特別注意一下「–link=mysql_server:db」,這個參數就是告訴Docker容器需要使用「mysql_server」容器,並將其別名命名為db,這樣在這兩個容器里就可以使用「db」來作為提供mysql資料庫服務的機器名。所以在最後啟動參數里我們使用的是「/usr/bin/mysql -h db -u root -pletmein」來連接mysql資料庫的。
運行完上面兩個命令,我們就會在創建了兩個mysql的client的容器,此時我們可以使用下面命令來查看狀態
復制代碼
代碼如下:
sudo docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
ac0c76c627c0 kongxx/mysql_client:latest /usr/bin/mysql -h db 10 seconds ago Up 9 seconds mysql_client2
763c4825722d kongxx/mysql_client:latest /usr/bin/mysql -h db 41 minutes ago Up 40 minutes mysql_client
32f7839f7e9d kongxx/mysql_server:latest /usr/bin/mysqld_safe About an hour ago Up About an hour 0.0.0.0:49153->3306/tcp mysql_client1/db,mysql_client2/db,mysql_server
這里注意一下最後一行,也就是mysql_server容器的「NAMES」列的內容「mysql_client/db,mysql_client2/db,mysql_server」,這就說明mysql_client1和mysql_client2都和db建立的連接。
❹ 已經有了阿里雲的centos系統 怎麼用docker搭建php
建議你裝個wdcp這類管理工具,可以方便的管理系統以及搭建服務已經有了阿里雲的centos系統 怎麼用docker搭建php
❺ centos7.2修復了docker哪些bug
在web根目錄下, 建立一個php文件,輸入 phpinfo ,然後看 搜 Loaded Configuration File,這個就是php.ini所在的目錄。
❻ 如何在CentOS6.5系統中安裝Docker
第一步 啟動CentOS 6.5 假設你已經安裝好了CentOS,虛擬機中或實體伺服器。 第二步 登陸系統 # yum install httpd vsftpd mysql mysql-server php php-mysql 為了自己能掌握,所以採取了默認輸入y確認安裝的方法。 第三步 確認安裝列表 # y 回車確認 第四步 設置開機啟動 # chkconfig httpd on 配置HTTP服務開機啟動。 # chkconfig vsftpd on 配置FTP服務開機啟動。 # chkconfig mysqld on 配置MySQL服務開機啟動。 第五步 檢查服務配置狀態 # chkconfig 2、3、4、5啟動。 第六步 啟動服務 # service httpd start 啟動HTTP服務。 # service vsftpd start 啟動FTP服務。 # service mysqld start 啟動MySQL服務。 第七步 配置FTP用戶、用戶組及相應許可權 # groupadd webftp 添加webftp用戶組,用來承載我們的FTP授權用戶。 # useradd -g webftp -M -d /var/www -s /sbin/nologin wwwer 使用-g參數將它歸集到webftp用戶組下,-M參數不設置它的主目錄(沒有-M參數/home里會有個wwwer文件夾,這個文件夾沒多少實際用處,所以不用設置),-d參數設定它的初始登入目錄為/var/www,-s參數設定它不需要登陸系統/sbin/nologin,它被命名為wwwer(之所以這樣命名,也就是根據初始登入目錄來設置的,下同,登陸到www目錄有一個好處是它可以直接FTP進去修改諸如404一類的頁面,而不用其他過程來配置)。 # useradd -g webftp -M -d /var/www/html -s /sbin/nologin htmler 同樣的方法在webftp用戶組繼續添加用戶htmler,它也不設置主目錄,也不需要登陸系統,設定它的初始登入目錄為/var/www/html。 # passwd wwwer 為wwwer添加密碼,兩次輸入。 # passwd htmler 為htmler添加密碼,兩次輸入。 # chown -R wwwer.webftp /var/www 更改/var/www目錄及其下所有文件和文件夾(-R)的所有者為webftp用戶組下的wwwer用戶。 # chown -R htmler.webftp /var/www/html 同樣將/var/www/html目錄及其下所有文件和文件夾chown給html。 第八步 不啟用匿名用戶 # vi /etc/vsftpd/vsftpd.conf 按I鍵進入編輯模式,找到anonymous_enable=YES,更改YES為NO,然後按ESC鍵退出編輯,輸入「:wq」存檔並退出。 第九步 配置基本安全策略 # getsebool -a grep ftp 列出所有selinux全部ftp策略。 #setsebool allow_ftpd_full_access on 允許FTP完全訪問。 # iptables -I INPUT -p tcp --dport 80 -j ACCEPT 插入防火牆規則(CentOS里用-A添加一條規則會處於鏈表尾,但表尾貌似不起作用,所以用-I插入到鏈表頭),這條規則的意思是所有INPUT到伺服器的包,-p如果是tcp協議的,--dport目標埠是80埠的,-j那麼就ACCEPT。 # iptables -I INPUT -p tcp --dport 21 -j ACCEPT 同樣的方法接受所有要到達伺服器21埠的tcp包。 # modprobe ip_conntrack_ftp 載入IP連線跟蹤模塊。記住最後這一步(第九步)的基本安全策略配置在重啟後全部失效,你需要重新配置一遍,當然通過修改selinux和iptables的配置文件或service iptables save是可以保持這些策略的。但你應該清晰的認識到一個問題:一個伺服器應該總是保持開啟狀態的,如果伺服器重啟了,那麼只有兩種可能,一種是在你的控制之下,一種不在你的控制之下,當伺服器重啟事件不在你的控制之下時,那麼你應該認識到這是很危險的情況,那麼剛才那些「放行」的策略應該完全失效而不是繼續保持才對。也正因為如此,我想這可能是CentOS這樣做的其中一個原因。如果你要添加的規則比較多可以先保存到一個txt文件里,直接cp過來就okay。
❼ CentOS8的podman容器
筆者在使用CentOS8時安裝docker失敗,於是發現CentOS8自帶容器podman,podman的使用方法和docker類似,命令行基本相同。同時和docker相比,podman是無守護程序容器引擎( Daemonless ),不能通過守護進程去實現自動重啟容器的功能,可以通過Systemd守護進程管理來開機啟動容器。同時,podman也不需要sudo訪問( Rootless )。
podman來運行nginx容器,命令和docker一樣,而且筆者使用的是docker的官方鏡像 docker.io/library/nginx。
1、podman搜索鏡像,有registry.redhat.io和docker.io可以選擇。
podman search nginx
2、podman拉取鏡像
podman pull docker.io/library/nginx
3、查看鏡像
podman images
4、運行容器,映射到宿主機8080埠。
podman run -itd --name podman-nginx -p 8080:80 docker.io/library/nginx
需要注意的是,筆者使用的是centos8,映射到小於1024埠時會提示錯誤:Error: failed to expose ports via rootlessport: "cannot expose privileged port 80, you might need to add \"net.ipv4.ip_unprivileged_port_start=0\" (currently 1024) to /etc/sysctl.conf, or choose a larger port number (>= 1024): listen tcp 0.0.0.0:80: bind: permission denied\n" 。
這時需要選擇一個大於等於1024的埠可以方便的解決。再次運行前需要將運行失敗的容器刪除podman rm podman-nginx ,不然會提示錯誤。
5、進入容器
podman exec -it podman-nginx bash
進入到nginx的根目錄:/usr/share/nginx/html,可以找到index.php文件。
6、查看容器運行成功
怎麼設置nginx容器開機啟動呢?可以參考文章-Systemd添加.service服務並設置開機啟動。
1、在/usr/lib/systemd/system目錄下新建podman_nginx.service
[Unit]
Description=Podman Nginx Service
After=network.target
[Service]
Type=simple
ExecStart=/usr/bin/podman start -a podman-nginx
ExecStop=/usr/bin/podman stop -t 10 podman-nginx
Restart=always
[Install]
WantedBy=multi-user.target
2、systemctl enable設置開機啟動
systemctl enable podman_nginx.service,激活開機啟動
systemctl enable --now podman_nginx.service ,可以激活開機啟動並啟動服務。
在/etc/systemd/system/multi-user.target.wants/目錄下可以看到這個鏈接文件。
❽ 在windows下創建docker run時應注意事項
docker run -itd -p 8080:80 -v E/phpstudy_pro/WWW:/usr/local/nginx/html --name centos-php73-1224 xingfupeng/php:7.3-fpm-centos7 /bin/bash
--name: 指定容器名稱
-p:指定容器埠號
-d:指定容器後台運行
--volume , -v: 綁定一個卷 如: -v /data:/data 以後台模式啟動一個容器,將容器的 80 埠映射到主機的 80 埠,主機的目錄 /data 映射到容器的 /data。
還有特別注意的點是:要先安裝docker desktop軟體,然後在設置里Settings-Resources-FILE SHARING 裡面要把上面的win目錄對應創建上,才能好使,要不然會出現docker: Error response from daemon: invalid mode此類的問題
要掛載目錄,不要掛載文件。
文件有緩存這個事情,我自己遇到了,因為是用git的,所以我先刪除文件,再git revert回來,就沒問題了
上面的應該是挺全的run了。
最新實踐:拉取東西要在docker里進行,git pull、git checkout 分支一類的,不要在IDE編輯器里進行,要不然不更新文件
❾ 用docker搭建nextcloud網盤
在centos系統上
添加鏡像加速器
新建/etc/docker/daemon.json
在域名控制台
創建一條A記錄,並指向伺服器IP地址
可以通過 ping 域名查看解析是否生效
添加並編輯構建文件
docker-compose.yml
4.構建上游伺服器
在本次教程中,我們採用 Docker + Caddy + PHP + SQLite 的構架。
Caddy 是一個非常優秀的上游伺服器(功能類似於 Nginx),但是它自帶免費申請 SSL證書 的功能,它的配置方法如下:
添加並構建caddyfile
5.啟動服務
讓docker-compose自動構建並維護docker即可
docker-compose up -d
通過docker-compose ps檢查docker的狀態
至此,nextcloud配置完畢
可訪問https://域名查看
❿ docker 安裝php擴展出錯,bash: docker-php-ext-install: command not found
不是這樣用的啊 進容器後 直接 yum install php 就完了 進容器後就不支持 docker+命令了