Docker命令:

docker images   查看本地镜像

docker ps -a   查询容器

docker ps -l   查询最近使用容器

docker rm CONTAINER_ID   删除容器

docker rmi IMAGE_ID   删除镜像

docker cp [OPTIONS] SRC_PATH CONTAINER_ID:DEST_PATH   上传文件/文件夹

docker cp [OPTIONS] CONTAINER_ID:SRC_PATH DEST_PATH   下载文件/文件夹

docker start CONTAINER_ID   启动容器

docker stop CONTAINER_ID   退出容器

docker kill CONTAINER_ID   强制退出容器

docker attach CONTAINER_ID   登录已启动容器

docker commit CONTAINER_ID xxxx/xxxxx[:xx]   保存对容器的修改

docker inspect CONTAINER_ID   查看容器的信息

ctrl+d    退出且关闭容器

ctrl+p,q      退出但不关闭容器

 

docker run命令详解

docker run [OPTIONS][COMMAND][ARG...]

OPTIONS说明:

  • --attach, -a: 指定标准输入输出内容类型,可选STDIN/STDOUT/STDERR三项;
  • --detach, -d: 后台运行容器,并返回容器ID;
  • --dns x.x.x.x: 指定容器使用的DNS服务器,默认和宿主一致;
  • --dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
  • --env, -e username="xxx": 设置环境变量;
  • --env-file=[]: 从指定文件读入环境变量;
  • --expose=[]: 开放一个端口或一组端口;
  • --hostname, -h "xxx": 指定容器的主机名;
  • --interactive, -i: 以交互模式运行容器,通常与 -t 同时使用;即使未连接,也要保持STDIN打开;
  • --link=[]: 添加链接到另一个容器;
  • --memory, -m: 设置容器使用内存最大值;
  • --name="xxx": 为容器指定一个名称xxx;
  • --net: 指定容器的网络连接类型,支持bridge/host/none/container:<name|id>四种类型;
  • --publish, -p: 端口映射,格式为:主机(宿主)端口:容器端口;
  • --privileged: 使容器内的root拥有真正的root权限,否则只是外部的一个普通用户权限;
  • --tty, -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;分配一个伪TTY;

docker run -it -p xxxx:xxxx xxx/xxx /bin/bash

 

docker search命令详解

docker search [OPTIONS] TERM

OPTIONS说明:

  --automated:只列出automated build类型的镜像;

  --no-trunc:显示完整的镜像描述;

  -f <过滤条件>:列出收藏数不小于指定值的镜像。

从Docker Hub查找所有镜像名包含java,并且收藏数大于10的镜像:

docker search -f stars=10 java

 

docker rm失败——容器处于dead状态:

根据docker rm失败产生的最后一串由字母与数字组成的字符串s,在命令行中输入grep [s]找到相关进程pid,然后kill [pid]。

最后再次grep [s],如果没有相关进程显示,即可以正常docker rm删除容器。

 

docker golang镜像使用:

docker run -it -p 8080:8080  docker.io/golang bash # 根据golang镜像产生一个新容器

docker run -it -p 8080:8080 -v /root/golang/go:/go -v /root/golang/code:/code --privileged docker.io/golang bash # 把本地目录映射到容器中

容器中的web应用监听的是容器端口,不同容器可以映射相同的容器端口,但是宿主机监听端口不能重复。

 

docker配置redis服务:

docker pull redis

docker run -it -p 56379:6379 docker.io/redis /bin/bash

exit

dokcer ps -l

docker exec -d CONTAINER_ID redis-server

 

docker配置mysql服务:

docker run -e MYSQL_ROOT_PASSWORD=123456 -p 53306:3306 -d docker.io/mysql

如果发现在容器中可以连接上数据库,而Navicat 远程连接docker容器中的mysql出现报错1251 - Client does not support authentication protocol

解决办法:

 

docker后台运行go webapi:

docker start webapi1
docker start webapi2
docker exec -d webapi1 bash -c "cd ../code/main && go run *.go"
docker exec -d webapi2 bash -c "cd ../code/main && go run *.go"

 

docker配置nginx服务:

docker run -it -p 80:80 docker.io/nginx bash
cd etc/nginx
vim nginx.conf

在http段加入以下代码

upstream 192.168.200.3{

  server 192.168.200.3:8081;

  server 192.168.200.3:8082;

}

cd conf.d

在etc/nginx/conf.d中运行vim default.conf

location / {  

   proxy_set_header Host $host;

   proxy_set_header X-Real-IP $remote_addr;

   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

   root /usr/share/nginx/html;

   index index.html index.htm;

   proxy_pass http://192.168.200.3;

}

重新启动nginx服务即可。

 

docker获取容器root权限

第一步:查看容器的CONTAINER ID

docker ps # 需要运行中的容器

第二步:获取root权限,例如需要进入的CONTAINER ID为2209371edd48

docker exec -ti -u root 2209371edd48 bash