docker容器内怎么连接外部的mysql?
1.用-v挂载主机数据卷到容器内
[plain]viewplaincopy
dockerrun-v/path/to/hostdir:/mnt$container
在容器内拷贝
cp/mnt/sourcefile/path/to/destfile
2.直接在主机上拷贝到容器物理存储系统
A.获取容器名称或者id:
[plain]viewplaincopy
$dockerps
B.获取整个容器的id
[plain]viewplaincopy
$dockerinspect-f'{{.Id}}'步骤A获取的名称或者id
C.在主机上拷贝文件:
[plain]viewplaincopy
$sudocppath-file-host/var/lib/docker/aufs/mnt/FULL_CONTAINER_ID/PATH-NEW-FILE
或者
$sudocppath-file-host/var/lib/docker/devicemapper/mnt/123abc>/rootfs/root
例子:
[plain]viewplaincopy
$dockerps
CONTAINERIDIMAGECOMMANDCREATEDSTATUSPORTSNAMES
d8e703d7e303solidleon/ssh:latest/usr/sbin/sshd-Dcranky_pare
$dockerinspect-f'{{.Id}}'cranky_pare
or
$dockerinspect-f'{{.Id}}'d8e703d7e303
d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5
$sudocpfile.txt/var/lib/docker/aufs/mnt/**d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5
3.用输入输出符
[plain]viewplaincopy
dockerrun-iubuntu/bin/bash-c'cat>/path/to/container/file'
或者
[plain]viewplaincopy
dockerexec-it
如果单指用docker的话 你有很多种办法。
1. 通过 docker run -p 将端口暴露出来 然后 PHP 通过 db 服务器的 IP ➕ port 进行连接
2. 你也可以使用 host 网络模式 通过指定 net 为 host 这种情况你也直接 IP ➕ port 连接
3. 你也可以加个代理容器 通过这个代理来将流量分发过去
通常情况下这三种办法已经能解决你绝大部分的问题了
docker部署什么类型项目?
您好,Docker可以部署各种类型的项目,包括但不限于以下几种:
1. Web应用程序:可以使用Docker容器来部署各种Web应用程序,如Java、Node.js、Python等。通过将应用程序和其依赖项打包到一个容器中,可以轻松地在不同环境中部署和运行。
2. 数据库:可以使用Docker容器来部署各种数据库,如MySQL、PostgreSQL、MongoDB等。通过使用容器化的数据库,可以简化数据库的安装和配置,并且可以方便地在不同环境中进行迁移和复制。
3. 消息队列和中间件:可以使用Docker容器来部署各种消息队列和中间件,如RabbitMQ、Kafka、Redis等。通过使用容器化的消息队列和中间件,可以方便地进行消息传递和异步处理。
4. 大数据和分布式系统:可以使用Docker容器来部署各种大数据和分布式系统,如Hadoop、Spark、Elasticsearch等。通过使用容器化的大数据和分布式系统,可以简化集群的管理和部署,并且可以方便地进行横向扩展和故障恢复。
5. 容器化的微服务架构:可以使用Docker容器来部署和管理微服务架构。通过将不同的微服务打包到不同的容器中,并使用容器编排工具(如Docker Compose、Kubernetes等)来管理容器之间的依赖关系和通信,可以实现高度可扩展和灵活的微服务架构。
总之,Docker可以部署几乎任何类型的项目,只要能将项目的依赖项打包到一个容器中,并且能够通过容器运行时来管理和运行。