docker命令笔记

1 篇文章 0 订阅
1 篇文章 0 订阅

docker命令笔记

视频地址:https://www.bilibili.com/video/BV1og4y1q7M4?p=27 强烈推荐!必须三连!

官网地址:https://www.docker.com

学习文档:https://docs.docker.com/compose/install
仓库地址:https://hub.docker.com
绘图地址:https://www.processon.com

uname -r #查看内核版本,安装docker要3.10以上
cat /etc/os-release #查看系统版本
yum remove docker docker-client docker-client-latest docker-commom docker-latest docker-latest-logrotate docker-logrotate docker-engine  #卸载docker
yum install -y yum-utils #安装依赖包
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # 安装docker
yum makecache fast #更新软件包索引
yum -y install docker-ce docker-ce-cli containerd.io #安装docker相关docker-ce社区版 ee企业版。一般安装ee
systemctl start docker #启动docker
systemctl enable docker #docker 开机自启
docker version #查看docker
docker run hello-world #测试docker
docker images #查看docker镜像
yum remove docker-ce docker-ce-cli containerd.io #卸载docker
rm -rf /var/lib/docker #删除docker相关文件
/var/lib/docker #默认资源路径
docker info #docker详细信息
docker --help #docker帮助
docker images -aq #查看image id
#REPOSITORY 仓库源 TAG 标签 IMAGE_ID 镜像id CREATED 创建时间 SIZE 大小
docker serach mysql --FILTER=STARS=3000 #查找下载数大于3000的
docker pull mysql:5.7 #拉取mysql5.7镜像
docker rmi -f id  #删除镜像
docker rmi -f $(docker images -aq) #删除所有镜像
docker pull centos #拉取centos
docker run  参数 image #run镜像
docker run -it centos /bin/bash #run centos
exit #退出
Ctrl+p+q #后台退出
docker ps -a #查看所有容器
docker ps -n=1 #查看最新的一个容器
docker rm id #删除容器
docker rm -f $(docker ps -aq) #删除所有容器
docker ps -aq | xargs docker rm #删除所有容器
docker start id #启动容器
docker stop id  #停止容器
docker restart id #重新启动容器
docker kill id   #强制停止容器
docker run -d centos #后台启动centos
docker run -d centos /bin/bash -c "while true;do echo zhl;sleep 2:done" #启动centos循环执行echo zhl
docker logs -tf --tail 10 容器id #查看容器日志
docker top id #查看容器进程
docker exec -it 容器id /bin/bash 
docker attach 容器id /bin/bash
docker cp 容器id:路径 宿主机路径
#部署nginx
docker search nginx
docker pull nginx
docker images
docker run -d --name nginx01 -p 3344:80 nginx
curl localhost:3344
docker exec -it nginx01 /bin/bash
whereis nginx
#部署tomcat
#部署ES+Kibana
docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discory.type=single-node" elasticsearth:6.7.2
dicker stats
docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discory.type=single-node" -e ES_JAVA_OPTS="Xms64m -Xmx512m" elasticsearth:6.7.2
#commit 镜像
docker run -it --name tomcat01 -p 8080:8080 tomcat
docker exec -it 234hjk24 /bin/bash
cp -r webapps.dist/* webapps/
docker commit -a="dfeczhl" -m="add webapps app" 234gh23dfs tomcat02:1.0
#docker run -d -it -v /home/tomcatceshi:/usr/local/tomcat/webapps/--privileged=true --name tomcatceshi001 -p 8089:8080 tomcat02:1.0 /bin/bash/
docker run -it -v /home/ceshi:/home centos /bin/bash
docker inspect 345hgj34g5h
#mysql容器持久化
docker pull mysql:5.7
docker run -d -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v \
/home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
#具名挂载和匿名挂载
docker run -d -p 80:80 --name nginx02 -v juming-nginx:/etc/nginx nginx
docker volume ls
#docker容器内的卷没有指定目录都在/var/lib/docker/volumes/下
docker run -d -P --name nginx01 -v /etc/nginx nginx
docker volume ls
ro rw

#Dockerfile
mkdir dockerfile-test-volume
vim dockerfile1
FROM centos
VOLUME ["vl1","vl2"]
CMD echo "---end---"
CMD /bin/bash
cat dockerfile1
docker build -f /home/dockerfile-test-volume/dockerfile1 -t zhl/centos .
docker images
docker run -it  324hjk23h4k /bin/bash
docker inspect 324gh23j4
cd /var/lib/docker/volumes \
/c2e5d9814999183133bf7f6d171160a7a07c1d650fec5db0f7ef9b0541d430c1/_data
#容器间实现数据同步 --volumes-from
docker run -it --name docker01 83178545ae5b
docker run -it --name docker02 --volumes-from docker01 83178545ae5b

#dockerfile指令
FROM # 基础镜像,一切从这里开始 90%都是由此开始
MAINRANINER #镜像是谁写的,姓名+邮箱
RUN #镜像构建时需要运行的命令
ADD # 步骤,tomcat镜像,这个tomcat压缩包!添加内容!
WORKDIR #镜像的工作目录
volume #挂载的目录
EXPOST #保留端口配置
CMD #指令,这个容器启动时运行的命令
ENTRYOINT #指定这个容器启动的时候要运行的命令,可以追加命令
ONBUILD  #宕构建一个被继承的Dockerfile,这个时候就会运行ONBUILD的指令,吃法指令
COPY #类似AA ,将我们文件拷贝的镜像中
ENV #构建的时候设置环境变量

#Dockerfile命令实战测试
#1、创建一个自己centons
mkdir dockerfile
vim mydockerfile-centos
FROM c


#Dcokerfile打包一个自己的原版tomcat镜像(官方命名Dcokerfile)
#1、准备自己的tomcat包,jdk包
FROM centos
MAINTAINER zhl<526050350@qq.com>
COPY readme.txt /usr/local/readme.txt
ADD jdk-8u192-linux-x64.tar.gz /usr/local/
ADD apache-tomcat-8.5.43.tar.gz /usr/local/
RUN yum -y install vim
RUN yum -y install network-untils
RUN yum -y  install -y net-tools 
ENV MYPATH /usr/local
WORKDIR $MYPATH
ENV JAVA_HOME /usr/local/jdk1.8.0_192
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV CATALINA_HOME /usr/local/apache-tomcat-8.5.43
ENV CATALINA_BASH /usr/local/apache-tomcat-8.5.43
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
EXPOSE 8080
CMD /usr/local/apache-tomcat-8.5.43/bin/startup.sh && tail -F /usr/local//usr/local/apache-tomcat-8.5.43/bin/logs/

docker run -d -p 8081:8080 --name zhltomcat0 -v /home/zhl/build/zhltomcat02/test:/usr/local/apache-tomcat-8.5.43/webapps/test -v zhltomclogs02:/usr/local/apache-tomcat-8.5.43/logs --net zhlnet diytomcat

#打包springbootjar包
RROM java:8
COPY *.jar /app.jar
CMD ["--server.port=8080"]
EXPOSE 8080
ENTRYPOINT["java","-jar","/app.jar"]




#docker默认网络(不特殊指定都是默认docker0,相当于是网关)
ip addr #docker0地址。安装了docker就是安装了一个网卡,使用桥接模式,技术是evth-pair技术。
#每启动一个容器,宿主机会多一个网卡
#evth-pair技术,一堆虚拟接口,成对出现;
docker exec -it tomcat01 ip addr # 查看容器地址
#linux宿主机可以ping同容器内部
#容器和容器之间是可以互相通信的,通过docker0网关来通信。
#只要删除,成对网络就是消失。

#项目不重启,数据库ip换掉了,希望可以通过名字来访问。直接ping名字ping不通。
--link  #在hosts配置中增加了一条记录
docker run -d -P --name tomcat03 --link tomcat02 tomcat 
#3到2可以通,反向不通。
docker network ls #显示docker网络
docker network inspect  网络id #当前网络信息
--link 不建议使用

#docke自定义网络---docker网络现实实用
docker network ls #查看所有docker网络
bridge #桥接网络
none   #不配置网络
host #和宿主机共享网络
container #容器网络联通(用的少,局限很大)
docker run -d -P --name tomcat01 --net bridge tomcat #直接启动的命令 --net bridge 就是默认的docker0
#docker0特点:默认,域名不能访问,--link可以打通链接,不建议。
docker network create --driver bridge --subnet 192.166.0.1/16 --gateway 192.166.0.1 zhlnet #创建自己的网络
#--driver bridge
#--subnet 192.166.0.0/16 192.166.0.2 192.166.255.255
#--gateway 192.166.0.1
docker network ls
docker network inspect zhlnet
#我们自己的网络就创建好了
docker run -d -P --name tomcat01-zhl-net --net zhlnet tomcat
docker run -d -P --name tomcat02-zhl-net --net zhlnet tomcat
docker exec -it tomcat01-zhl-net ping 192.168.0.2
docker exec -it tomcat01-zhl-net ping tomcat01-zhl-net


#推荐以后这样使用网络
docker network --help
docker network connect --help
docker network connect mynet tomcat01 #tomcat01放到zhlnet里面,一个容器两个网卡 打通两个容器群













#安装dockercompose 地址:https://docs.docker.com/compose/install/
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose #dockercompose 下载地址
sudo chmod +x /usr/local/bin/docker-compose # 赋执行权限
sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose # 做链接
docker-compose --version #查看docker—compose 版本
#部署个人博客wordpress 
#下载安装地址:https://docs.docker.com/samples/wordpress/
mkdir my_wordpress # 创建目录
cd my_wordpress/   #进入目录
vim docker-compose.yml  #创建docker-compose.yml

version: "3.9"
    
services:
  db:
    image: mysql:5.7
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: somewordpress
      MYSQL_DATABASE: wordpress
      MYSQL_USER: wordpress
      MYSQL_PASSWORD: wordpress
    
  wordpress:
    depends_on:
      - db
    image: wordpress:latest
    volumes:
      - wordpress_data:/var/www/html
    ports:
      - "8000:80"
    restart: always
    environment:
      WORDPRESS_DB_HOST: db:3306
      WORDPRESS_DB_USER: wordpress
      WORDPRESS_DB_PASSWORD: wordpress
      WORDPRESS_DB_NAME: wordpress
volumes:
  db_data: {}
  wordpress_data: {}

docker-compose up -d #后台启动




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值