网站建设模版 优帮云,高端女装有哪些品牌,施工企业的安全生产责任制度,电子商务网站建设作业案例云平台核心
第一章 为什么用云平台
环境统一按需付费即开即用稳定性强
一、国内常见云平台
阿里云、百度云、腾讯云、华为云、青云…
二、国外常见云平台
亚马逊 AWS、微软 Azure …
三、公有云 购买云服务商提供的公共服务器 公有云是最常见的云计算部署类型。公有云资…云平台核心
第一章 为什么用云平台
环境统一按需付费即开即用稳定性强
一、国内常见云平台
阿里云、百度云、腾讯云、华为云、青云…
二、国外常见云平台
亚马逊 AWS、微软 Azure …
三、公有云 购买云服务商提供的公共服务器 公有云是最常见的云计算部署类型。公有云资源例如服务器和存储空间由第三方云服务提供商拥有和运营这些资源通过 Internet 提供。在公有云中所有硬件、软件和其他支持性基础结构均为云提供商所拥有和管理。Microsoft Azure 是公有云的一个示例。 在公有云中你与其他组织或云“租户”共享相同的硬件、存储和网络设备并且你可以使用 Web 浏览器访问服务和管理帐户。公有云部署通常用于提供基于 Web 的电子邮件、网上办公应用、存储以及测试和开发环境。 公有云优势 成本更低无需购买硬件或软件仅对使用的服务付费。无需维护维护由服务提供商提供。近乎无限制的缩放性提供按需资源可满足业务需求。高可靠性具备众多服务器确保免受故障影响。 可用性 N个9 9 全年的故障时间 365243600*(1-99.9999%)
四、私有云 自己搭建云平台或者购买 私有云由专供一个企业或组织使用的云计算资源构成。私有云可在物理上位于组织的现场数据中心也可由第三方服务提供商托管。但是在私有云中服务和基础结构始终在私有网络上进行维护硬件和软件专供组织使用。 这样私有云可使组织更加方便地自定义资源从而满足特定的 IT 需求。私有云的使用对象通常为政府机构、金融机构以及其他具备业务关键性运营且希望对环境拥有更大控制权的中型到大型组织。 私有云优势 灵活性更强组织可自定义云环境以满足特定业务需求。控制力更强资源不与其他组织共享因此能获得更高的控制力以及更高的隐私级别。可伸缩性更强与本地基础结构相比私有云通常具有更强的可伸缩性。
五、总结 没有一种云计算类型适用于所有人。多种不同的云计算模型、类型和服务已得到发展可以满足组织快速变化的技术需求。 部署云计算资源有三种不同的方法公共云、私有云和混合云。采用的部署方法取决于业务需求。
第二章 核心构架
一、所需软件
electerm https://electerm.github.io/electerm/xshell
二、注册云平台
阿里云 aliyun.com腾讯云 cloud.tencent.com华为云 huaweicloud.com青云 qingcloud.com百度云 cloud.baidu.com
三、基础概念
云服务器作为应用的最终载体VPC为所有云服务器提供网络隔离所有云服务器都是绑定某个私有网络安全组控制每个服务器的防火墙规则公网IP使得资源可访问端口转发的方式访问到具体服务器
四、实战
开通按量付费服务器开通基于VPC的服务器集群 同一VPC下的服务器可互通不同vpc下的服务器在物理层做了网络隔离不可互通。
Docker 基础
第一章 Docker基本概念
一、解决的问题
1. 统一标准
1.1 应用构建
Java、C、JavaScript打成软件包.exedocker build … 镜像
1.2 应用分享
所有软件的镜像放到一个指定地方 docker hub安卓应用市场
1.3 应用运行
统一标准的 镜像docker run
1.4 虚拟化技术
基础镜像GB级别创建使用稍微复杂隔离性强启动速度慢移植与分享不方便
1.5 容器化技术
基础镜像MB级别创建简单隔离性强启动速度秒级移植与分享方便
2. 资源隔离
cpu、memory资源隔离与限制访问设备隔离与限制网络隔离与限制用户、用户组隔离限制
二、架构 Docker_Host 安装Docker的主机 Docker Daemon 运行在Docker主机上的Docker后台进程 Client 操作Docker主机的客户端命令行、UI等 Registry 镜像仓库Docker Hub Images 镜像带环境打包好的程序可以直接启动运行 Containers 容器由镜像启动起来正在运行中的程序 交互逻辑 装好Docker然后去 软件市场 寻找镜像下载并运行查看容器状态日志等排错
三、安装
1. centos下安装docker
1.1 移除以前docker相关包
sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine1.2 配置yum源
sudo yum install -y yum-utils
sudo yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo1.3 安装docker
sudo yum install -y docker-ce docker-ce-cli containerd.io#以下是在安装k8s的时候使用
yum install -y docker-ce-20.10.7 docker-ce-cli-20.10.7 containerd.io-1.4.61.4 启动
systemctl enable docker --now1.5 配置加速
这里额外添加了docker的生产环境核心配置cgroup
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json -EOF
{registry-mirrors: [https://82m9ar63.mirror.aliyuncs.com],exec-opts: [native.cgroupdriversystemd],log-driver: json-file,log-opts: {max-size: 100m},storage-driver: overlay2
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker第二章 Docker命令实战
一、基础实战
1. 找镜像
去docker hub找到nginx镜像
docker pull nginx #下载最新版镜像名:版本名标签docker pull nginx:1.20.1docker pull redis #下载最新
docker pull redis:6.2.4## 下载来的镜像都在本地
docker images #查看所有镜像redis redis:latestdocker rmi 镜像名:版本号/镜像id2. 启动容器
启动nginx应用容器并映射88端口测试的访问
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]【docker run 设置项 镜像名 】 镜像启动运行的命令镜像里面默认有的一般不会写# -d后台运行
# --restartalways: 开机自启
docker run --namemynginx -d --restartalways -p 88:80 nginx# 查看正在运行的容器
docker ps
# 查看所有
docker ps -a
# 删除停止的容器
docker rm 容器id/名字
docker rm -f mynginx #强制删除正在运行中的#停止容器
docker stop 容器id/名字
#再次启动
docker start 容器id/名字#应用开机自启
docker update 容器id/名字 --restartalways3. 修改容器内容
修改默认的index.html 页面
3.1 进容器内部修改
# 进入容器内部的系统修改容器内容
docker exec -it 容器id /bin/bash3.2 挂载数据到外部修改
docker run --namemynginx \
-d --restartalways \
-p 88:80 -v /data/html:/usr/share/nginx/html:ro \
nginx# 修改页面只需要去 主机的 /data/html4. 提交改变
将自己修改好的镜像提交
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]docker commit -a alex -m 首页变化 341d81f7504f alexnginx:v1.0镜像传输
# 将镜像保存成压缩包
docker save -o abc.tar alexnginx:v1.0# 别的机器加载这个镜像
docker load -i abc.tar# 离线安装5. 推送远程仓库
推送镜像到docker hub应用市场
docker tag local-image:tagname new-repo:tagname
docker push new-repo:tagname# 把旧镜像的名字改成仓库要求的新版名字
docker tag alexnginx:v1.0 alex/alexnginx:v1.0# 登录到docker hub
docker login docker logout推送完成镜像后退出# 推送
docker push alex/alexnginx:v1.0# 别的机器下载
docker pull alex/alexnginx:v1.06. 补充
docker logs 容器名/id 排错docker exec -it 容器id /bin/bash# docker 经常修改nginx配置文件
docker run -d -p 80:80 \
-v /data/html:/usr/share/nginx/html:ro \
-v /data/conf/nginx.conf:/etc/nginx/nginx.conf \
--name mynginx-02 \
nginx#把容器指定位置的东西复制出来
docker cp 5eff66eec7e1:/etc/nginx/nginx.conf /data/conf/nginx.conf
#把外面的内容复制到容器里面
docker cp /data/conf/nginx.conf 5eff66eec7e1:/etc/nginx/nginx.conf二、进阶实战
1. 编写自己的应用
编写一个HelloWorld应用https://start.spring.io/
2. 将应用打包成镜像
编写Dockerfile将自己的应用打包镜像
2.1 以前
Java为例 SpringBoot打包成可执行jar把jar包上传给服务服务器运行java -jar
2.2 现在
所有机器都安装Docker任何应用都是镜像所有机器都可以运行
2.3 怎么打包-Dockerfile
FROM openjdk:8-jdk-slim
LABEL maintaineralexCOPY target/*.jar /app.jarENTRYPOINT [java,-jar,/app.jar]docker build -t java-demo:v1.0 .3. 启动容器
3.1 启动应用容器
docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0 3.2 分享镜像
# 登录docker hub
docker login#给旧镜像起名
docker tag java-demo:v1.0 alex/java-demo:v1.0# 推送到docker hub
docker push alex/java-demo:v1.0# 别的机器
docker pull alex/java-demo:v1.0# 别的机器运行
docker run -d -p 8080:8080 --name myjava-app java-demo:v1.0 4. 部署中间件
部署一个Redis应用尝试应用操作Redis产生数据
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]#redis使用自定义配置文件启动docker run -v /data/redis/redis.conf:/etc/redis/redis.conf \
-v /data/redis/data:/data \
-d --name myredis \
-p 6379:6379 \
redis:latest redis-server /etc/redis/redis.conf