Docker基础使用
Docker篇
CentOS 安装Docker - 菜鸟教程
安装须知:
1.Docker支持以下的CentOS版本:
CentOS 7 (64-bit)
CentOS 6.5 (64-bit) 或更高的版本
2.Docker 要求 CentOS 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker 。
通过 uname -r 命令查看你当前的内核版本
安装一些必要的系统工具:
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
添加软件源信息:
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
更新 yum 缓存:
sudo yum makecache fast
安装 Docker-ce:
sudo yum -y install docker-ce
启动 Docker 后台服务
sudo systemctl start docker
测试运行 hello-world
[root@runoob ~]# docker run hello-world
会自动下载一个镜像运行
注意配置CDN加速:
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决,我使用的是网易的镜像地址:http://hub-mirror.c.163.com。
新版的 Docker 使用 /etc/docker/daemon.json(Linux) 或者 %programdata%\docker\config\daemon.json(Windows) 来配置 Daemon。
请在该配置文件中加入(没有该文件的话,请先建一个):
{
"registry-mirrors": ["http://hub-mirror.c.163.com"]
}
Docker正式使用常见命令
Docker-Hub注册:https://hub.docker.com/signup
Docker验证登录
docker login
Docker寻找镜像
docker search tomcat
Docker拉取镜像
docker pull tomcat
Docker查看本地镜像
docker images
Docker删除镜像和容器
docker删除镜像:
docker rmi 镜像ID
如果是本地的包含tag的话需要指明
docker rmi 806857264/kerwin_docker:kerwin_tomcat_8080
docker删除容器:
首先需要停止容器
docker stop 【id名字】
docker rm 【id名字】
Docker查看正在运行的容器
docker ps
查看所有容器
docker ps -a
Docker交互模式进入到目标文件目录
docker exec -it d585d5151285 /bin/bash 交互模式进入到目标文件目录,可以进行修改等,如进入到tomcat目录
d585d5151285为容器ID
停止容器/重启容器
docker stop 【名字】
docker start 【名字】
docker restart 【名字】
Docker运行镜像
如tomcat为例:
docker run --name tomcat-80 -p 80:8080 -v /home/docker_tomcat:/usr/local/tomcat/webapps -d tomcat
重命名为tomcat-80 端口映射 80->8080 宿主机文件交互目录 运行的镜像为tomcat :ro赋予可读权限
Docker部署redis
redis.conf 配置文件 ---
创建:/home/docker_redis/conf
创建:/home/docker_redis/data
ze yes
#设置进程锁文件
pidfile /redis/redis.pid
#端口
port 6379
#客户端超时时间
timeout 1500
#日志级别
loglevel debug
#日志文件位置
logfile /log/log-docker_redis.log
#设置数据库的数量,默认数据库为0,可以使用SELECT <dbid>命令在连接上指定数据库id
databases 8
##指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合
#save <seconds> <changes>
#Redis默认配置文件中提供了三个条件:
save 900 1
save 300 10
save 60 10000
#指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,如果为了节省CPU时间,
#可以关闭该#选项,但会导致数据库文件变的巨大
rdbcompression yes
#指定本地数据库文件名
dbfilename dump.rdb
#指定本地数据库路径
dir /redis/db/
#指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能
#会在断电时导致一段时间内的数据丢失。因为 redis本身同步数据文件是按上面save条件来同步的,所以有
#的数据会在一段时间内只存在于内存中
appendonly no
#指定更新日志条件,共有3个可选值:
#no:表示等操作系统进行数据缓存同步到磁盘(快)
#always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)
#everysec:表示每秒同步一次(折衷,默认值)
appendfsync everysec
#redis配置外网访问:
protected-mode no
#配置密码
requirepass 123456
运行命令:
如redis为例:
docker run -d --privileged=true -p 56379:6379 -v /docker/redis/conf/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data --name redis_56379 redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass 123456
映射ip 56379->6379 映射宿主机文件夹(配置文件和数据) 启动redis-server 按配置文件启动 密码规定为123456
Docker部署nginx进行反向代理
docker pull nginx
创建对应文件夹,进行目录映射
运行nginx镜像:
docker run --name nginx-80 -d -p 80:80 -v /home/docker_nginx/html:/usr/share/nginx/html -v /home/docker_nginx/nginx.conf:/etc/nginx/nginx.conf:ro -v /home/docker_nginx/conf.d:/etc/nginx/conf.d nginx
ip映射80,文件夹映射,注意nginx.conf:ro 可读权限,conf.d目录下存放对应的配置即可
Nginx配置说明:
nginx.conf 核心配置,可不用修改
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
Nginx - conf.d目录下配置,针对每一个域名的具体配置
说明:一个域名对应一个文件,如kkzhilu.cn为例
upstream tomcat {
#内网IP,然后限制8080端口对外访问,即可保证用户只从nginx进入,提高访问上限
#另外,如微服务架构的话,限制端口,也可以保证用户只能从网关层进入,保证后台服务的安全
server 172.21.0.8:8080;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat;
}
}
参考博文:
docker 快速部署tomcat:https://blog.csdn.net/weixin_39835887/article/details/84516595
51博客:https://blog.51cto.com/11134648/2160257
菜鸟教程
how2j
博客园创建安装基本命令等:https://www.cnblogs.com/lsgxeva/p/8746644.html
镜像制作:https://www.cnblogs.com/iloverain/p/8980275.html
docker 快速部署redis:https://blog.csdn.net/wcuuchina/article/details/86355362
Docker制作镜像推送到仓库
博文地址:https://www.cnblogs.com/yaohong/p/9221800.html
1.制作镜像,可以从公网随意拉一个容器,本地运行,再把它变成镜像即可
2.比如我拉取了tomcat镜像,配置之后会变成容器
3.把最终的运行容器变成镜像
先停止容器运行,再执行:
docker commit -m "my_tomcat" -a "kerwin" tomcat-8080 kerwin_tomcat_8080:v1.0
-m 描述,-a作者 后面是镜像名,然后的推送之后的镜像名最后是版本号
打标,通过images拿到对应镜像的id,再给它重新打标
docker tag 179396596cbd 806857264/kerwin_docker:kerwin_tomcat_8080
docker --- 命令
tag --- 命令
179396596cbd --- 镜像id
806857264/kerwin_docker: --- 用户名和仓库名(仓库没有的话自动创建,所以不用自己去建)
kerwin_tomcat_8080 --- 取的是commit的最终镜像名
最后是push
docker push 806857264/kerwin_docker:kerwin_tomcat_8080
kerwin_tomcat_8080 就是上文打标的目标镜像
去官网:https://cloud.docker.com/repository/list
检查即可
注:为什么要commit推送, 因为在容器内部修改的,配置的文件,在关闭启动之后,会消失,所以,如果有改动内部文件,则需要制作新的镜像,然后推送,如果仅仅是宿主机目录的变化的话,是不需要重新制作镜像的
Docker部署第三方Jar包
指导博文:https://www.cnblogs.com/bxssjava/p/9978449.html
第一步:准备好一个正常完好的jar
第二步:Dockerfile文件 注意不要有后缀
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD target/demo_test_nginx-0.0.1-SNAPSHOT.jar app.jar
RUN sh -c 'touch /app.jar'
ENV JAVA_OPTS=""
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
第三步:在linux服务器指定的目录下,放好jar和dockerfile文件
第四步:docker build -t 【镜像名字】 .
注意上面的. 表示此目录
第五步:正常运行即可
如:docker run --name demo-10909 -p 10909:10909 -d viando/demo
Docker 自动化部署 - shell命令
创建 docker.sh文件,写入以下命令,将之和jar以及Dockerfile放在一个目录,必要的时候修改 app名,容器名或者镜像名即可
注意必要情况修改端口映射
#!/bin/bash
#JAR 名称 - 替换即可
APP_NAME=demo_test_nginx-0.0.1-SNAPSHOT.jar
#容器名称 - 替换即可
CONTAINER_NAME=demo-10909
#镜像名称 - 替换即可
IAMGE_NAME=viando/demo
#使用说明,用来提示输入参数
usage() {
echo "Usage: sh 执行脚本.sh [start|build] desc: start is for run jar and build is build images for docker"
exit 1
}
#启动方法-包含build过程
start(){
build
docker run --name $CONTAINER_NAME -v /home/log:/log -p 10909:10909 -d $IAMGE_NAME
#挂载日志
}
#构建image方法
build(){
docker stop $CONTAINER_NAME
docker rm $CONTAINER_NAME
docker rmi $IAMGE_NAME
#构建
docker build -t $IAMGE_NAME .
}
#根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
"start")
start
;;
"build")
build
;;
*)
usage
;;
esac
Docker基础使用的更多相关文章
- Docker - Docker基础命令及使用
Docker Docker - 官网 Docker - Hub GitHub - Docker Docker中文社区 Docker基础命令 Docker 查看帮助信息:docker --help 查看 ...
- 【云计算】Docker云平台—Docker基础
Docker云平台系列共三讲,此为第一讲:Docker基础 参考资料: Docker官方文档:https://docs.docker.com/ Docker从入门到实践:https://yeasy.g ...
- Docker基础技术:Linux Namespace(下)
在 Docker基础技术:Linux Namespace(上篇)中我们了解了,UTD.IPC.PID.Mount 四个namespace,我们模仿Docker做了一个相当相当山寨的镜像.在这一篇中,主 ...
- Docker 基础技术:Linux Namespace(下)
导读 在Docker基础技术:Linux Namespace(上篇)中我们了解了,UTD.IPC.PID.Mount 四个namespace,我们模仿Docker做了一个相当相当山寨的镜像.在这一篇中 ...
- Docker基础入门及示例
Docker近几年的发展可谓一日千里,特别从是2013年随着一个基于LXC的高级容器引擎开源,到现在,其在linux和windows上都有了很好的支持,并且已经有很多公司将docker用于实际的生产环 ...
- Docker 基础 : 镜像
目录 获取镜像 查看镜像信息 搜索镜像 删除镜像 创建镜像 导出和导入镜像 上传镜像 总结 镜像是 Docker 的三大核心概念之一.Docker 运行容器前需要本地存在对应的镜像,如果本地没有对应的 ...
- Docker 基础技术之 Linux cgroups 详解
PS:欢迎大家关注我的公众号:aCloudDeveloper,专注技术分享,努力打造干货分享平台,二维码在文末可以扫,谢谢大家. 推荐大家到公众号阅读,那里阅读体验更好,也沉淀了很多篇干货. 前面两篇 ...
- docker 基础知识分享ppt
给团队做的docker基础分享ppt, 见下面的附件. https://files.cnblogs.com/files/harrychinese/docker_intro.pptx
- 中标麒麟龙芯平台--docker基础镜像制作
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源.Docker 的出现为开发人员和运维人员带来了极大的便利.Docker在X86下常见的发行版Linux如Ub ...
- Docker系列03—Docker 基础入门
本文收录在容器技术学习系列文章总目录 1.概念介绍 1.1 容器 1.1.1 介绍 容纳其它物品的工具,可以部分或完全封闭,被用于容纳.储存.运输物品.物体可以被放置在容器中,而容器则可以保护内容物. ...
随机推荐
- 关于单向循环链表的约瑟夫问题(Java实现)
关于单向循环链表的约瑟夫问题(Java实现) 最近在学习链表时,遇到单向循环链表中的约瑟夫问题.在构建循环链表的代码上,我有一点很不理解,遂记录下来. Josephu问题为: 设编号为1, 2,.. ...
- winxp系统连接服务器丢包解决方法
winxp系统连接服务器丢包解决方法 MFC编写一个打开网页的程序,发生异常没有获取到数据. 分析步骤: 1. 用getLastError()获取到的信息,(2)- 系统找不到指定的文件. 2. 用浏 ...
- 1.尚硅谷_MyBatis_简介.avi
hibernate旨在消除mysql语句.程序员不写sql语言,要实现复杂的功能需要学习hibernate的hql语句 mybatis把编写sql语言交给程序员,程序员自己在xml控制sql语句的编写 ...
- Python 简明教程 --- 11,Python 元组
微信公众号:码农充电站pro 个人主页:https://codeshellme.github.io 软件工程的目标是控制复杂度,而不是增加复杂性. -- Dr. Pamela Zave 目录 我们在上 ...
- 计算机网络之DDOS
1.什么是DDOS DDOS(Distributed Denial of Service),中文意思为“分布式拒绝服务”,就是利用大量合法的分布式服务器对目标发送请求,从而导致正常合法用户无法获得服务 ...
- 主线程用afxBeginThread()创建多个线程安全退出的办法
HANDLE hand[]; CCriticalSection m_crisecoin; CEvent m_event; struct Student { int nNO; int nYear; CW ...
- 洛谷P1220关路灯【区间dp】
题目描述 某一村庄在一条路线上安装了 \(n\) 盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少).老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一盏一盏地关掉这些路灯 ...
- 题解 P3870 【[TJOI2009]开关】/基础分块学习小结
直接进入正题: 分块: 分块分块,就是把一个长串东西,分为许多块,这样,我们就可以在操作一个区间的时候,对于在区间里面完整的块,直接操作块,不完整的直接操作即可,因为不完整,再加上一个块本身就不大,复 ...
- c++ 宏定义调用不定参数的函数
假设有一下函数 void Logging(int nLevel, const char* szFormat, ...); 则宏定义如下 #define LOG(FCFL) Logging##FCFL ...
- Python必须知道的异常处理
异常处理 把可能会发生的错误,提前在代码里进行捕捉(监测) try : code except Exception: 出错后要执行的代码 下面是常见的异常: attributeError 试图访问一个 ...