我正在使用docker通过以下命令在单独的容器中启动Nginx,PHP和mariaDB:
# DB
docker run --name db -d -p 3306:3306 --restart=always -v /opt/db:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=<pass> -e MYSQL_USER=dbuser -e MYSQL_PASSWORD=<pass> mariadb
# PHP
docker run --name php -p :9000 -d --restart=always --link=db:db -v /www:/data php:fpm
# WEB
docker run --name web -d -p 80:80 --link php --link=db:db -v /www:/data -v /opt/nginx/default.conf:/etc/nginx/conf.d/default.conf nginx:latest
Run Code Online (Sandbox Code Playgroud)
(当然,我已经填好了我的密码)到目前为止,到目前为止,在本地运行了一个旋转的Nginx,我可以在http:// localhost上正确显示的www文件夹中看到index.htm和phpinfo.php。
接下来,我创建了一个dbcheck.php页面,其中包含以下内容:
<?php
$dbh = mysqli_connect('localhost', 'dbuser', '<pass>');
if (!$dbh) {
die('Could not connect: ' . mysqli_error());
}
echo 'Connected successfully to MariaDB database';
mysqli_close($dbh);
?>
Run Code Online (Sandbox Code Playgroud)
结果是PHP没有安装MySQL扩展。我在做什么错和/或如何安装MySQL扩展(以及在哪里安装)
小智 5
请使用db代替主机名localhost。因此,代码将像这样
$dbh = mysqli_connect('db', 'dbuser', '<pass>');
Run Code Online (Sandbox Code Playgroud)
因为您使用此选项将php容器与mariadb容器链接在一起--link=db:db。这意味着您链接到db容器并将其命名为db。因此,php容器仅db是mariadb容器的主机名
| 归档时间: |
|
| 查看次数: |
465 次 |
| 最近记录: |