第1章 【阶段一:Go语言基础】1~13章内容
1-1 Go+Python双语言混合开发-课程导学 (11:35)
1-2 课程资源获取方式 – 非常重要!!! (06:07)
1-3 课程中需要用到的开发环境介绍 (03:47)
1-4 windows中安装centos7虚拟机 (19:16)
1-5 xshell的安装和使用 (04:14)
1-6 git的安装和配置 (06:22)
1-7 docker和docker-compose的安装 (10:31)
1-8 mysql和navicat的安装和配置 (10:09)
1-9 python的安装和配置 (08:58)
1-10 python虚拟环境的安装和配置 (09:49)
1-11 pycharm的安装和配置 (11:46)
1-12 windows下安装go和goland的配置 – 很重要!! (24:47)
1-13 linux下go开发环境搭建 (04:55)
1-14 windows下安装nodejs开发环境 (04:38)
1-15 linxu下安装和配置nodejs开发环境 (04:32)
1-16 代码提示神器 – kite的安装和配置 (07:19)
1-17 go语言介绍 (14:51)
1-18 go的hello world-1 (24:40)
1-19 变量的定义 (18:09)
1-20 匿名变量是什么? (07:21)
1-21 go语言中的常量是什么? (15:16)
1-22 常量的iota有什么用? (21:28)
1-23 变量的作用域也有很多细节你可能没有在意 (17:44)
第2章 计算机组成原理快速扫盲
2-1 为什么我们要学习计算机组成原理 (11:11)
2-2 二进制、八进制和十六进制 (18:28)
2-3 ascii码表是什么? (25:44)
第3章 基本数据类型、运算符和表达式
3-1 go语言提供了哪些整数类型? (24:44)
3-2 float类型和其它数据类型 (16:25)
3-3 go语言最基本的数据类型转换 (16:05)
3-4 strconv的parse类函数将字符串转换为其他类型 (23:41)
3-5 python的基本数据类型转换 (08:04)
3-6 go语言运算符 (18:20)
第4章 python的海象运算符和变量注解
4-1 python3.8的新特性-海象运算符 (19:11)
4-2 python的变量居然也能申明类型! (16:01)
4-3 python如何强制检查函数的参数类型 (20:26)
第5章 字符串的基本操作
5-1 为什么len函数获取中文字符串长度有问题? (13:50)
5-2 什么是转义符? (08:49)
5-3 子串查询、子串统计、开始和结尾判断 (08:48)
5-4 子串的替换、连接和分割 (14:40)
5-5 格式化的输入和输出 (27:32)
第6章 条件语句和循环语句
6-1 if条件控制语句 (09:47)
6-2 go语言的for循环 (22:00)
6-3 go语言的for range用法 (12:54)
6-4 goto语句能帮我们完成什么功能? (12:32)
6-5 switch语句能让代码可读性更高 (21:37)
6-6 python中如何实现switch的效果? (08:12)
第7章 最常用的复杂数据类型 – map、数组、 切片
7-1 数组的多种初始化方式 (24:36)
7-2 使用for range对数组元素求和 (07:08)
7-3 go语言中的数组是值类型 – 很重要! (14:39)
7-4 go语言的slice是什么? (26:21)
7-5 slice切片的的基本操作 (21:20)
7-6 go和python的切片的区别 (06:46)
7-7 slice使用的时候你有没有遇到过这些奇怪的现象? (10:51)
7-8 slice的底层存储原理-1 (23:00)
7-9 slice的底层存储原理-2 (20:25)
7-10 当append函数遇到make会产生的坑 (11:16)
7-11 map的定义和基本操作 (25:27)
第8章 go语言的利器- 指针
8-1 什么是指针 (35:35)
8-2 go的指针和c语言的指针有什么区别? (05:03)
8-3 make函数和new函数 (11:56)
8-4 图解new函数的执行过程 (10:27)
8-5 go语言中的nil和python中的None有什么区别? (08:13)
第9章 go语言的函数
9-1 函数的各种定义 (17:59)
9-2 通过省略号设置参数个数不定长 (10:00)
9-3 go语言中的函数是一等公民 (33:20)
9-4 python中的finally的执行顺序你真的弄懂了吗? (20:11)
9-5 defer的作用和多个defer的执行顺序 (22:12)
9-6 defer机制你忽略了很多细节 (21:53)
9-7 python是如何处理代码错误和异常的? (25:22)
9-8 panic和recover的坑 (33:06)
第10章 go语言的结构体
10-1 type的5种应用场景 (13:22)
10-2 python中的class封装性和namedtuple (20:23)
10-3 结构体的定义以及大小写对结构的影响 (18:50)
10-4 结构体的实例化和new函数 (35:59)
10-5 结构体如何绑定方法? (21:03)
10-6 通过内嵌结构体实现继承的效果 (20:37)
10-7 结构体标签的作用是什么? (24:47)
第11章 go语言的接口
11-1 python中的鸭子类型就是go的接口设计理念 (33:31)
11-2 go语言中的接口是一种类型 (12:20)
11-3 为什么说接口是一种抽象类型? (26:44)
11-4 接口也支持继承 (09:00)
11-5 go的error是一个接口 (07:29)
11-6 空接口的应用场景 (11:53)
11-7 接口的类型断言 (16:53)
11-8 通过接口协议去理解sort的本质 (22:07)
第12章 包管理和编码规范
12-1 如何使用go modules (15:09)
12-2 go的包和python的包区别 (26:33)
12-3 go的import的各种姿势 (13:58)
12-4 package和init函数的关系 (06:32)
12-5 gopath开发模式和go modules开发模式对比 (21:09)
12-6 go编码规范-1 (21:35)
12-7 go编码规范 – 2 (17:53)
12-8 python编码规范 (04:32)
第13章 go并发编程
13-1 go的goroutine (27:05)
13-2 go的协程和python协程对比 (18:30)
13-3 使用waitgroup控制协程退出 (09:15)
13-4 使用互斥锁同步协程 (19:55)
13-5 使用RWMutex锁同步协程 (15:01)
13-6 通过channel进行goroutine间的通信 (19:57)
13-7 通过for range遍历channel和close关闭channel (10:47)
13-8 双向和单向的channel (14:01)
13-9 使用channel容易出现deadlock的原因 (16:38)
13-10 go中select的应用场景 (18:20)
13-11 context的应用场景 (27:02)
13-12 通过context控制超时 (09:36)
第14章 【阶段二:多语言通信基础 – grpc】14~17章内容
14-1 什么是rpc?rpc开发的挑战是什么?-1 (19:49)
14-2 什么是rpc?rpc开发的挑战是什么?- 2 (16:48)
14-3 使用httpsserver实现rpc (23:57)
14-4 rpc的开发要素分析 (09:38)
14-5 基于xml的rpc库 (12:20)
14-6 基于json的rpc技术 (27:23)
14-7 基于zeromq的rpc框架 (36:07)
第15章 go的rpc体验
15-1 go快速体验rpc开发 (24:49)
15-2 替换rpc的序列化协议为json (20:07)
15-3 替换rpc的传输协议为https (09:33)
15-4 进一步改造rpc调用的代码-1 (25:22)
15-5 进一步改造rpc调用的代码-2 (14:10)
第16章 grpc快速入门
16-1 什么是grpc和protobuf (14:56)
16-2 python下体验protobuf (22:13)
16-3 python体验grpc开发 (24:59)
16-4 python下生产的grpc文件import路径有问题的探讨 (09:09)
16-5 go下grpc快速体验 – 1 (17:41)
16-6 go下grpc快速体验-2 (18:12)
16-7 go和python互相调用 (14:03)
16-8 grpc的流模式的定义 (21:14)
16-9 grpc的单向流,双向流代码实现 (24:41)
第17章 protobuf和grpc进阶
17-1 protobuf的基本类型和默认值,python操作的坑 (15:41)
17-2 option go_package的作用 (06:40)
17-3 当proto文件不同步的时候容易出现的问题 (12:28)
17-4 proto文件中引入其他的proto文件 (10:20)
17-5 嵌套的message对象 (12:02)
17-6 protobuf中的enum枚举类型 (07:14)
17-7 map类型 (05:11)
17-8 使用protobuf内置的timestamp类型 (06:44)
17-9 grpc配合asyncio使用 (23:58)
17-10 grpc的metadata机制-go (21:35)
17-11 python操作metada (10:05)
17-12 grpc拦截器 – go (21:18)
17-13 python实现grpc的拦截器 (11:56)
17-14 通过拦截器和metadata实现grpc的auth认证 (17:50)
17-15 grpc的验证器 (32:11)
17-16 grpc中的错误处理 (25:31)
17-17 grpc的超时机制 (07:10)
第18章 【阶段三:需求分析、架构设计、orm和web框架基础】18~22章内容
18-1 如何启动电商系统和后台管理系统 (05:01)
18-2 后台管理系统需求 (05:57)
18-3 电商系统需求分析 (06:31)
第19章 架构设计
19-1 单体应用如何部署? (10:58)
19-2 单体应用开发痛点 (15:55)
19-3 单体应用的架构演变 (18:07)
19-4 服务拆分变动 (08:57)
19-5 微服务的基本拆分 (09:44)
19-6 分层微服务架构 (11:16)
19-7 微服务需要解决的问题 – 重要!! (21:02)
第20章 yapi的安装和配置
20-1 前后端分离的系统开发演变过程 (09:47)
20-2 接口文档管理之痛 (07:46)
20-3 yapi的安装和配置 (14:31)
20-4 yapi基本功能使用 (16:31)
20-5 接口的导入和导出 (11:03)
第21章 python的orm-peewee
21-1 peewee的安装和入门-1 (22:36)
21-2 peewee的安装和入门 – 2 (22:20)
21-3 数据的更新和删除 (15:46)
21-4 多条插入、 or查询 (25:43)
21-5 模糊查询、字典展示、排序、limit和去重 (17:35)
21-6 聚合函数、执行原生的sql语句 (12:52)
21-7 多表查询和反向查询 (25:39)
21-8 避免n加1查询问题 (05:34)
第22章 go的web框架-gin
22-1 gin的helloworld体验 (12:51)
22-2 使用New和Default初始化路由器的区别 (06:54)
22-3 gin的路由分组 (09:25)
22-4 获取url中的变量 (20:46)
22-5 获取get和post表单信息 (16:46)
22-6 gin返回protobuf (18:36)
22-7 登录的表单验证 (18:28)
22-8 注册表单的验证 (12:25)
22-9 表单验证错误翻译成中文 (18:04)
22-10 表单中文翻译的json格式化细节 (09:12)
22-11 自定义gin中间件 (17:26)
22-12 通过abort终止中间件后续逻辑的执行 (12:26)
22-13 gin的中间件原理源码分析 (10:22)
22-14 gin返回html (25:00)
22-15 加载多个html文件 (14:37)
22-16 static静态文件的处理 (05:38)
22-17 gin的优雅退出 (14:36)
第23章 【第四阶段:第一个微服务 – 用户服务】23~25章内容
23-1 新建虚拟环境和项目 (07:28)
23-2 user表结构设计和生成 (27:11)
23-3 md5信息摘要 (14:29)
23-4 md5盐值加密解决用户密码安全问题 (18:05)
23-5 proto接口定义和生成 (21:25)
23-6 用户列表接口 (19:53)
23-7 启动grpc服务 (11:00)
23-8 日志库选型 – loguru (17:46)
23-9 优雅退出server (12:13)
23-10 通过argparse解析传递进入的参数 (08:46)
23-11 通过id和mobile查询用户是否存在 (11:25)
23-12 新建用户接口 (15:23)
23-13 更新用户 (06:07)
第24章 web层开发-gin基础项目架构
24-1 新建项目和目录结构构建 (05:41)
24-2 go高性能日志库 – zap使用 (14:40)
24-3 zap的文件输出 (08:27)
24-4 集成zap和理由初始到gin的启动过程 – 1 (14:23)
24-5 集成zap和理由初始到gin的启动过程-2 (14:54)
24-6 gin调用grpc服务-1 (22:59)
24-7 gin调用grpc服务-2 (21:56)
24-8 配置文件 – viper (24:09)
24-9 viper的配置环境开发环境和生产环境隔离 (20:02)
24-10 viper集成到gin的web服务中 (16:03)
第25章 web层开发-用户接口开发
25-1 表单验证的初始化 (26:51)
25-2 自定义mobile验证器 (14:10)
25-3 登录逻辑完善 (18:05)
25-4 session机制在微服务下的问题 (09:01)
25-5 json web token的认证机制 (11:16)
25-6 集成jwt到gin中 (21:02)
25-7 给url添加登录权限验证 (15:07)
25-8 如何解决前后端的跨域问题 (23:30)
25-9 获取图片验证码 (23:41)
25-10 阿里云发送短信 (22:53)
25-11 redis保存验证码 (22:46)
25-12 用户注册接口 (21:40)
第26章 【阶段五:服务注册、服务发现、负载均衡、配置中心】26~29章内容
26-1 什么是服务注册和发现以及技术选型 (18:52)
26-2 consul的安装和配置 (17:13)
26-3 服务注册和注销 (19:31)
26-4 服务注册的健康检查 (12:28)
26-5 配置grpc的健康检查 (15:30)
26-6 第三方库实现服务注册 (24:28)
26-7 go集成consul (19:48)
第27章 服务集成注册中心
27-1 srv服务集成consul (23:16)
27-2 gin集成consul (20:52)
27-3 将用户的grpc连接配置到全局共用 (11:30)
第28章 负载均衡
28-1 动态获取可用端口 (16:00)
28-2 什么是负载均衡,负载均衡的策略有哪些? (23:28)
28-3 常用负载均衡算法 (09:21)
28-4 grpc从consul中同步服务信息并进行负载均衡-1 (18:50)
28-5 grpc从consul中同步服务信息并进行负载均衡-2 (09:34)
28-6 gin集成grpc的负载均衡 (06:40)
第29章 配置中心
29-1 为什么需要配置中心 (14:30)
29-2 配置中心选型-apollo vs nacos (07:36)
29-3 nacos的安装 (05:29)
29-4 nacos的组、配置集、命名空间 (14:30)
29-5 python操作nacos配置 (15:47)
29-6 service层集成nacos (11:52)
29-7 go操作nacos (15:17)
29-8 gin集成nacos (25:46)
第30章 【阶段六:电商系统中商品、图片、库存、订单和购物车服务、分布式锁】30~38章
30-1 需求分析_ (03:55)
30-2 商品分类的表机构设计 (05:24)
30-3 物理删除还是逻辑删除 (22:38)
30-4 其余表结构定义和数据导入 (12:21)
30-5 定义proto文件 (12:17)
30-6 商品服务器的启动 (14:15)
30-7 商品列表页服务接口-1 (19:34)
30-8 商品列表页服务接口-2 (14:36)
30-9 测试商品列表页 (14:16)
30-10 批量获取商品信息 (08:15)
30-11 获取商品的详情和删除商品 (09:51)
30-12 新建商品接口 (21:26)
30-13 更新商品接口 (03:13)
30-14 商品分类列表页-1 (14:36)
30-15 商品分类列表页-2 (13:54)
30-16 商品分类的其他接口 (09:59)
30-17 轮播图相关功能 (06:23)
30-18 品牌相关接口 (06:30)
30-19 品牌分类相关接口 (12:40)
第31章 商品服务-web等
31-1 快速将用户的web服务转换成商品的web服务 (21:08)
31-2 商品的列表页接口-1 (18:28)
31-3 商品的列表页接口-2 (14:20)
31-4 如何设计一个符合go风格的注册中心接口 (23:01)
31-5 gin的退出后的服务注销 (06:00)
31-6 用户的web服务服务注册和优雅退出 (05:39)
31-7 新建商品 (21:37)
31-8 获取商品详情 (09:35)
31-9 商品删除,更新 (18:08)
31-10 商品分类的接口 (23:43)
31-11 轮播图接口和yapi的快速测试 (18:49)
31-12 品牌和品牌分类接口 (proto同步脚本) (16:23)
31-13 品牌分类接口 (13:29)
第32章 阿里云的oss服务
32-1 为什么要使用阿里云oss (07:58)
32-2 oss的基本概念介绍 (10:55)
32-3 使用代码控制文件上传 (19:02)
32-4 前端直传oss的流程 (15:51)
32-5 gin集成前端直传文件 (21:43)
32-6 为什么我们需要内网穿透 (09:45)
32-7 内网穿透技术解决前端直传的回调 (15:15)
32-8 将oss集成到gin微服务中 (16:02)
第33章 库存服务
33-1 库存服务的重要性 (07:43)
33-2 库存服务表结构设计 (10:20)
33-3 proto接口设计 (14:15)
33-4 配置启动库存服务 (11:09)
33-5 设置库存和获取库存详情 (09:09)
33-6 库存的扣减和事务 (14:53)
33-7 库存归还 (05:26)
33-8 测试库存服务接口 (14:11)
33-9 为所有的商品添加库存信息 (04:21)
第34章 分布式锁
34-1 订单超卖问题是如何产生的? (24:32)
34-2 什么是分布式锁 (10:59)
34-3 基于mysql的乐观锁机制实现 (23:26)
34-4 redis分布式锁实现的基本原理 (24:54)
34-5 基于setnx确保分布式锁的原子性 (06:51)
34-6 如何解决分布式锁中的重点难题 (21:57)
34-7 py-redis-lock核心源码分析 (14:22)
34-8 集成redis分布式锁到库存服务 (10:11)
34-9 基于redis的分布式锁的优缺点和其他的分布式锁实现方案 (06:40)
第35章 订单和购物车服务-service层
35-1 需求分析 (06:25)
35-2 表结构设计 (12:45)
35-3 proto文件定义 (19:53)
35-4 启动订单服务 (09:36)
35-5 购物车列表、添加商品到购物车接口 (10:58)
35-6 更新购物车、删除购物车接口 (06:43)
35-7 订单的列表页接口 (09:45)
35-8 订单详情页接口 (12:46)
35-9 新建订单 – 访问商品服务 (24:03)
35-10 新建订单 – 访问库存扣减 (10:18)
35-11 新建订单-本地事务确保创建成功 (16:06)
35-12 测试接口 (17:32)
第36章 订单和购物车服务-web等
36-1 快速启动订单服务 (21:31)
36-2 购物车列表页接口 (16:08)
36-3 添加商品到购物车 (16:18)
36-4 更新和删除购物车记录 (20:56)
36-5 订单列表页 (18:03)
36-6 订单详情接口开发和测试 (14:32)
36-7 新建订单接口开发和测试 (11:32)
第37章 用户操作服务-service层
37-1 支付宝沙箱环境开发流程 (05:43)
37-2 私钥、公钥的概念以及支付宝如何解决订单的安全性问题 (20:09)
37-3 支付宝的公钥、私钥和回调url配置 (08:29)
37-4 生成支付宝的支付url (13:50)
37-5 gin集成支付宝支付_3 (17:57)
37-6 支付宝回调通知url逻辑接口 (19:15)
第38章 用户操作服务-web等
38-1 需求分析和表结构定义 (08:31)
38-2 proto接口定义 (07:06)
38-3 运行用户操作服务 (10:36)
38-4 handler的代码解读 (08:22)
38-5 web服务启动 (14:06)
38-6 解读handler的代码 (20:04)
38-7 调试收藏、收货地址、留言接口 (10:40)
第39章 前后端联调
39-1 启动online-store服务 (11:21)
39-2 首页接口的请求分析 (06:21)
39-3 商品列表页分析 (05:11)
39-4 个人中心、订单相关功能联调 (08:40)
39-5 前端文件直传的源码解析 (05:51)
39-6 用户详情和更新接口 (14:14)
39-7 后台管理系统-商品列表页 (13:37)
39-8 品牌接口联调 (07:33)
39-9 用户信息相关功能联调 (10:47)
第40章 【阶段七:分布式系统技术难点 – 分布式事务、幂等性机制】39~44章内容
40-1 为什么订单会有超时机制 (14:09)
40-2 数据库事务的ACID特性 (15:03)
40-3 分布式系统中出现哪些故障会导致数据不一致? (09:21)
第41章 分布式理论基础和常见的分布式事务解决方案
41-1 cap理论 (15:25)
41-2 BASE理论 (10:19)
41-3 2pc两阶段提交分布式事务 (11:09)
41-4 TCC分布式事务实现方案 (17:41)
41-5 TCC分布式事务实现方案-2 (17:46)
41-6 基于本地消息的最终一致性方案 (12:36)
41-7 基于可靠消息的最终一致性 (15:35)
41-8 最大努力通知方案 (14:53)
第42章 消息队列在微服务中的作用和选型
42-1 mq的应用场景.mp4 (16:05)
42-2 mq消息队列技术选型.mp4 (14:32)
第43章 rocketmq消息队列入门
43-1 rocketmq的安装和配置.mp4 (15:10)
43-2 rocketmq的基本概念.mp4 (05:26)
43-3 rocketmq的消息类型.mp4 (14:25)
43-4 在linux中搭建python的rocketmq开发环境.mp4 (08:16)
43-5 pycharm在windows下获取linux下的开发体验.mp4 (05:45)
43-6 python发送rocketmq普通消息.mp4 (11:09)
43-7 python消费普通消息.mp4 (07:46)
43-8 python发送延迟消息.mp4 (06:46)
43-9 python发送事务消息 (12:52)
第44章 实现基于可靠消息最终一致性的事务解决库存归还
44-1 开始之前的网络问题 – 重要!!! (05:58)
44-2 订单新建的过程中如果保证库存数据的最终一致性 (13:58)
44-3 库存扣减在分布式事务中的特殊性 (06:45)
44-4 订单新建前的事务消息准备 (15:18)
44-5 基于回调实现消息的通信 (12:01)
44-6 什么时候应该对事务消息进行确认? (09:25)
44-7 库存扣减事务的完善 (11:13)
44-8 库存服务监听rocketmq消息 (04:55)
44-9 库存扣减记录下扣减历史 (15:32)
44-10 库存归还的细节处理 (06:50)
44-11 启动所有微服务的注意事项 (11:08)
44-12 测试分布式事务一致性 (10:48)
44-13 订单超时归还的流程分析 (06:43)
44-14 订单新建成功后发送延时消息 (06:24)
44-15 订单超时后的库存归还实现 (11:52)
44-16 测试库存的超时归还 (04:33)
第45章 幂等性机制
45-1 什么是服务雪崩 (09:47)
45-2 超时、重试和幂等性机制 (10:53)
45-3 哪些情况下需要考虑幂等性问题 (08:03)
45-4 go的grpc重试机制 (09:50)
45-5 python下实现重试机制 (06:30)
45-6 常用的幂等性解决方案 (11:54)
第46章 【阶段八:微服务的高可用保障 – 链路追踪、熔断、限流、降级】45~48章内容
46-1 为什么我们需要链路追踪 (11:17)
46-2 链路追踪技术选型 (07:16)
46-3 jaeger的安装和架构介绍 (08:42)
第47章 第二章 链路追踪open tracing和jaeger
47-1 python发送单个span (13:11)
47-2 发送多级调用的span消息 (12:22)
47-3 grpc下发送span消息 (11:24)
47-4 grpc下client_interceptor的源码解读 (10:55)
47-5 grpc下server端发送span消息 (05:25)
47-6 grpc下server_interceptor的源码解读 (04:42)
47-7 在grpc的server端添加子链路 (06:51)
第48章 gin和python集成jaeger
48-1 go发送简单的span消息 (09:16)
48-2 go下通过grpc发送span消息 (11:09)
48-3 gin中添加拦截器实现jaeger注入 (20:31)
48-4 修改grpc_opentracing源码 (17:18)
48-5 配置订单服务的web层逻辑 (10:00)
48-6 订单服务的service链路追踪实现 (13:43)
第49章 熔断、限流 – sentinel
49-1 什么是限流、熔断和降级 (15:15)
49-2 sentinel和hystrix对比 (05:47)
49-3 sentinel的qps限流 (20:04)
49-4 sentinel的预热和冷启动 (19:19)
49-5 sentinel的Throttling配置策略 (05:10)
49-6 sentinel的熔断接口 (09:39)
49-7 sentinel的熔断接口-基于错误数 (11:26)
49-8 sentinel的熔断接口-基于错误率和慢请求 (07:05)
49-9 gin集成sentinel实现限流 (11:09)
49-10 python下集成CircuitBreaker (09:01)
49-11 python下使用ratelitmit进行限流 (04:25)
第50章 【阶段九:API网关】49~50章内容
50-1 什么是api网关 (07:25)
50-2 api网关具备的功能有哪些? (04:53)
50-3 api网关技术选型 (09:21)
50-4 kong的安装 (20:48)
第51章 kong的基本功能
51-1 kong的8001、800和1337端口号的关系 (08:03)
51-2 基本的路由转发配置 (09:47)
51-3 kong的service、routes、upstream的请求过程 (06:22)
51-4 kong集成consul实现服务发现和负载均衡 (07:05)
51-5 kong配置jwt实现登录校验 (16:11)
51-6 kong配置反爬和ip黑名单 (09:04)
第52章 【阶段十:jekins自动化部署】51~51章内容
52-1 敏捷开发中的持续集成痛点 (15:46)
52-2 安装jenkins和关闭防火墙 (12:47)
52-3 jenkins构建服务器流程 (11:59)
52-4 安装jenkins常用插件 (09:51)
52-5 通过free style构建项目 (15:00)
52-6 将构建服务器上的代码上传到运行服务器 (16:41)
52-7 通过pipeline实现持续集成 (20:23)
52-8 通过jenkinsfile管理构建pipeline脚本 (06:11)
52-9 通过远程和其他工程触发构建 (07:13)
52-10 定时构建和轮询SCM构建 (08:35)
52-11 参数化pipeline构建项目 (05:13)
第53章 jekins自动化部署
53-1 有哪些服务器我们需要部署? (11:32)
53-2 前端代码上传到git并启动 (09:12)
53-3 nginx中部署vuejs (24:50)
53-4 jenkens部署vuejs项目 (24:11)
53-5 通过go build构建go微服务 (23:19)
53-6 发布go项目到远程服务器上 (09:07)
53-7 通过shell脚本启动gin服务 (12:29)
53-8 构建和部署python微服务-1 (16:31)
53-9 构建和部署python微服务-2 (23:12)
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。