相关文章 Docker总结1/3—理论篇 Docker总结3/3—备份迁移和仓库
这些镜像都是存储在Docker宿主机的/var/lib/docker目录下
如果你需要从网络中查找需要的镜像,可以通过以下命令搜索
docker search 镜像名称 内容含义NAME仓库名称DESCRIPTION镜像描述STARS用户评价,反应一个镜像的受欢迎程度OFFICIAL是否官方AUTOMATED自动构建,表示该镜像由Docker Hub自动构建流程创建的拉取镜像就是从中央仓库中下载镜像到本地
docker pull 镜像名称按镜像ID删除镜像
docker rmi 镜像ID删除所有镜像(删除镜像需要保证,镜像中没有容器,否则需要先删除容器,再删除镜像。)
docker rmi `docker images -q`查看正在运行的容器
docker ps查看所有容器
docker ps –a查看最后一次运行的容器
docker ps –l查看停止的容器
docker ps -f status=exited创建容器常用的参数说明:
创建容器命令: docker run
命 令含义-i运行容器-t容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端–name为创建的容器命名-v目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上-d在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。-p端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射通过ps命令查看,发现可以看到启动的容器,状态为启动状态
docker run -it --name=容器名称 镜像名称:标签 /bin/bash退出当前容器
exit登录守护式容器方式:
docker exec -it 容器名称 (或者容器ID) /bin/bash 交互式创建容器守护式创建容器直接进入容器内部,退出之后,容器停止。不会容器内部,exec进入容器内部之后,再退出,容器依然运行状态。停止容器:
docker stop 容器名称(或者容器ID)启动容器:
docker start 容器名称(或者容器ID)如果我们需要将文件拷贝到容器内可以使用cp命令
docker cp 需要拷贝的文件或目录 容器名称:容器目录也可以将文件从容器内拷贝出来
docker cp 容器名称:容器目录 需要拷贝的文件或目录我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。
创建容器 添加-v参数 后边为 宿主机目录:容器目录例如:
docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7如果你共享的是多级的目录,可能会出现权限不足的提示。
这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题
我们可以通过以下命令查看容器运行的各种数据
docker inspect 容器名称(容器ID)也可以直接执行下面的命令直接输出IP地址
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)删除指定的容器:
docker rm 容器名称(容器ID)连接宿主机的IP ,指定端口为33306 本地测试连接:
创建容器 -p表示地址映射 (端口映射+目录挂载)
docker run -di --name=mytomcat -p 9000:8080 -v /usr/local/webapps:/usr/local/tomcat/webapps tomcat:7-jre7【测试tomcat部署内容】
上传cas.war文件
转移cas.war文件到刚才创建的目录 mv cas.war /usr/local/web
浏览器输入 “服务器IP地址:映射的端口号/cas” 即可看到上传的文件页面:
(端口映射)
docker run -di --name=mynginx -p 80:80 nginx【测试nginx部署的页面】
查看上传的页面的位置(此步骤可以不操作)
[root@localhost ~]# docker exec -it mynginx /bin/bash root@348ce53d721c:/# dir bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var root@348ce53d721c:/# cd etc/nginx root@348ce53d721c:/etc/nginx# dir conf.d fastcgi_params koi-utf koi-win mime.types modules nginx.conf scgi_params uwsgi_params win-utf root@348ce53d721c:/etc/nginx# cd conf.d root@348ce53d721c:/etc/nginx/conf.d# dir default.conf root@348ce53d721c:/etc/nginx/conf.d# cat default.conf root@348ce53d721c:/etc/nginx/conf.d# cd /usr/share/nginx/html/ root@348ce53d721c:/usr/share/nginx/html# dir 50x.html index.html root@348ce53d721c:/usr/share/nginx/html# exit exit [root@localhost ~]# dir anaconda-ks.cfg html mynginx.tar dist 上传文件到根目录 sftp> put -r 文件夹路径 移动文件到创建的mynginx容器下 [root@localhost ~]# mv dist html [root@localhost ~]# docker cp html mynginx:/usr/share/nginx 打开浏览器输入:服务器IP地址,访问上传的页面即可。(端口映射)
docker run -di --name=myredis -p 6379:6379 redis【测试redis部署】
#查看命令redis的id [root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 40a25b0c17b5 redis "docker-entrypoint.s…" 11 minutes ago Up 11 minutes 0.0.0.0:6379->6379/tcp myredis #进入redis容器内部 [root@localhost ~]# docker exec -it 61afc2919bb6 redis-cli #设置一个值、并将值取出 127.0.0.1:6379> set hello stephanie OK 127.0.0.1:6379> get hello "stephanie"[redis被外网访问] redis自带安全机制,默认情况下,不能被外网访问。 通过服务端,开发端口,即可实现外网访问redis。
①官网下载redis.conf并修改端口号为外网可访问的端口号。 0.0.0.0为所有网络都可访问,但不安全。
②上传redis文件
sftp> put D:\material\Netease\redis.conf③目录挂载 (实现文件互传)
docker run -p 6379:6379 --name redis -v /data/redis/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes④移动文件到redis的目录
mv redis.conf /data/redis/redis.conf⑤查看redis.conf文件内容,完成目录
[root@localhost redis]# cd /data/redis [root@localhost redis]# ll data redis.conf [root@localhost redis]# cd redis.conf [root@localhost redis]# vi redis.conf [root@localhost redis.conf]# vi redis.conf到这里Docker常用命令,和常用软件的部署就结束了。