容器是基于Docker镜像被创建的。
docker run [Options] image
运行容器
docker run [Options] image
#参数说明
--name="名字" 指定容器名字
-d 后台方式运行
-it 使用交互方式运行,进入容器查看内容
-p 指定容器的端口
-p ip:主机端口:容器端口 配置主机端口映射到容器端口
-p 主机端口:容器端口(常用)
-p 容器端口
-P 随机指定端口
-e 环境设置
-v 容器数据卷挂载
运行并进入容器centos
[root@localhost ~]# docker run -it centos /bin/bash
[root@ce2bbae9f151 /]# ls
bin etc lib lost+found mnt proc run srv tmp var
dev home lib64 media opt root sbin sys usr
进入容器,因为通常我们的容器都是使用后台方式来运行的,有时需要进入容器修改配置
docker exec -it 容器id /bin/bash
# docker exec 进入容器后开启一个新的终端,可以在里面操作
docker exec -it 容器id /bin/bash
docker attach 容器id
# docker attach 进入容器正在执行的终端
docker attach 容器id
退出容器
exit # 停止容器并退出(后台方式运行则仅退出)
Ctrl+P+Q # 不停止容器退出
docker ps
查看运行的容器
# 查看当前正在运行的容器
docker ps
-a # 查看所有容器的运行记录
-n=? # 显示最近创建的n个容器
-q # 只显示容器的id
docker start 容器id
启动容器
docker start 容器id # 启动容器
docker restart 容器id # 重启容器
docker stop 容器id # 停止当前运行的容器
docker kill 容器id # 强制停止当前容器
docker logs 容器id
查看容器运行日志
docker logs -tf 容器id
docker logs --tail num 容器id # num为要显示的日志条数
docker top 容器id
查看容器中进程信息
docker top 容器id
docker inspect 容器id
查看容器的元数据
docker inspect 容器id
# 1.启动mysql 设置密码、设置挂载数据卷
docker run -d -p 3306:3306 --name mymysql -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql
# 2.远程连接mysql服务,若无权限,进入mysql容器中修改远程连接权限
docker exec -it 36d4806c765a /bin/bash
# 登录mysql
mysql -u root -p
# 修改root 可以通过任何客户端连接
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
修改远程连接权限成功后,可以通过Navicat等mysql客户端连接数据库。
启动nginx挂载和其他容器挂载有所区别,需要进行额外操作。
docker挂载是run时挂载,所以要先copy配置文件,如果不copy直接挂载启动容器时会从挂载的目录找配置文件,找不到会启动失败。
1. 运行容器
docker run --name nginx -d -p 7777:80 nginx
2. 在宿主机上创建挂载目录
mkdir -p /home/docker/volumes/nginx/conf
mkdir -p /home/docker/volumes/nginx/log
3. 从容器中复制配置文件到挂载目录
docker cp nginx:/etc/nginx/nginx.conf /home/docker/volumes/nginx/conf/nginx.conf #从容器中复制配置文件
docker cp nginx:/etc/nginx/conf.d /home/docker/volumes/nginx/conf/ #从容器中复制配置文件夹
docker cp nginx:/usr/share/nginx/html /home/docker/volumes/nginx/ #从容器中复制html文件
docker cp nginx:/var/log/nginx /home/docker/volumes/nginx/log #从容器中复制日志文件
4. 删除nginx容器
docker stop nginx
docker rm nginx
5. 使用挂载的方式重新启动nginx
chmod 777 /home/docker/volumes/nginx/conf/nginx.conf
docker run -d -p 7777:80 --name nginx \
-v /home/docker/volumes/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /home/docker/volumes/nginx/conf/conf.d:/etc/nginx/conf.d \
-v /home/docker/volumes/nginx/html:/usr/share/nginx/html \
-v /home/docker/volumes/nginx/log:/var/log/nginx \
-e LANG=C.UTF-8 -e LC_ALL=C.UTF-8 \
--privileged=true --restart=always nginx
配置说明:
docker run -p 6379:6379 -d --name myredis \
-v /home/docker_volume/redis/data:/data \
-v /home/docker_volume/redis/conf/redis.conf:/etc/redis/redis.conf \
redis redis-server /etc/redis/redis.conf --appendonly yes
进入redis容器
docker exec -it myredis redis-cli
docker run -it -d -p 5672:5672 -p15672:15672 --hostname my-rabbit --name my-rabbit \
-v /home/docker_volume/rabbit/:/var/lib/rabbitmq \
-e RABBITMQ_DEFAULT_USER=admin \
-e RABBITMQ_DEFAULT_PASS=admin rabbitmq:3-management
启动成功后,浏览器访问 http://ip:15672/,进入rabbitmq管理界面。
Kafka需要依赖于Zookeeper
docker run -it -d --restart=always --name zookeeper -p 2181:2181 wurstmeister/zookeeper
docker run -d --restart=always --name kafka -p 9092:9092 \
-e KAFKA_BROKER_ID=0 \
-e KAFKA_ZOOKEEPER_CONNECT=10.1.7.102:2181/kafka \
-e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://10.1.7.102:9092 \
-e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 \
-v /etc/localtime:/etc/localtime wurstmeister/kafka
docker run -it -d --name mytomcat -p 8090:8080 \
-v /home/docker_volume/tomcat/webapps/:/usr/local/tomcat/webapps tomcat
默认镜像中webapps目录为空,先将项目放入webapps目录下,再访问http://ip:8090/
# 进入tomcat容器
docker exec -it mytomcat /bin/bash
# 复制项目到webapps下
cp -rf webapps.dist/* webapps
jar包想要在docker中运行,需要把jar包制作成镜像文件,docker再运行镜像。Dockerfile详细教程请参考文章:Docker入门与进阶第三部分
1.将jar包上传到Linux中,并编写Dockerfile文件
[root@localhost idea]# ls
demo-0.0.1-SNAPSHOT.jar Dockerfile
2.Dockerfile文件内容
FROM java:8
# 将demo-0.0.1-SNAPSHOT.jar 复制 到容器中并重命名为 app.jar
COPY demo-0.0.1-SNAPSHOT.jar app.jar
CMD ["--server.port=8080"]
EXPOSE 8080
ENTRYPOINT ["java","-jar","app.jar"]
3.docker build构建镜像
[root@localhost idea]# docker build -t springbootdemo:1.0 .
[root@localhost idea]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
springbootdemo 1.0 d9648a49a226 50 seconds ago 661MB
4.运行、测试
[root@localhost idea]# docker run -d -p:8888:8080 --name mydemo springbootdemo:1.0
[root@localhost idea]# curl localhost:8888/hello
hello buckletime![root@localhost idea]#