ABP vNext微服务架构详细教程——镜像推送
1. Jenkins搭建
为实现容器化部署,我们需要将代码打包成镜像并推送至容器仓库,我们可以选择自建容器仓库或者使用公有云服务商提供的镜像仓库。这里我们使用阿里云提供的免费镜像仓库。
代码打包和镜像仓库推送有很多种方式,在实际项目中,我推荐使用Jenkins实现自动化打包推送。
我们这里我们使用Docker部署Jenkins,首先,安装Docker,这里我使用的Ubuntu系统,并使用一键安装脚本:
curl -sSL https://get.daocloud.io/docker | sh
之后我们需要开启Docker的2375端口方法如下:
vim /usr/lib/systemd/system/docker.service
#修改ExecStart行为下面内容:
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
加载配置项并重启Docker
systemctl daemon-reload
systemctl restart docker
之后使用Jenkins官方文档提供的部署命令如下:
docker run -u root --rm -d -p 8080:8080 -p 50000:50000 -v jenkins-data:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock jenkinsci/blueocean
运行成功后访问8080端口,可以进入Jenkins页面。
这里我们需要在宿主机上运行一下命令进入Jenkins控制台:
docker exec 【Jenkins容器ID】 -it /bin/bash
进入容器后使用以下命令获取第一次登录所需秘钥:
cat /var/jenkins_home/secrets/initialAdminPassword
登录后,依照默认选项配置Jenkins组件,并设置用户名密码,下次登录可使用新的用户名密码登录。
配置完成后进入管理面板,找到Manage Jenkins→插件管理→可选插件,搜索Docker,并安装。
安装完成后,在Manage Jenkins→系统配置中找到Cloud选项卡,点击“a separate configuration page.”并点击“Add a new cloud”按钮,选择docker。
点击“Docker Cloud details……”按钮,在Docker Host URI选项中填入docker地址如下:
tcp://【宿主机IP】:2375
点击“Test Connection”测试,通过后点击Save保存。
2. 配置Dockerfile
以基础服务中的产品服务为例,这里我们使用.Net官方提供的构建方式构建镜像,即将代码拷贝到.Net 6 SDK容器中执行打包和发布,再将发布后的文件拷贝到项目运行镜像中。
在Jenkins官方提供的Docker组件中,只能指定Dockerfile的目录,无法指定执行构建镜像的目录,所以我们需要让镜像构建的目录和Dockerfile一致。
在src\service\productmanager目录下添加Dockerfile文件内容如下:
1 FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
2 WORKDIR /app
3 EXPOSE 80
4
5 FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
6 WORKDIR /src
7 COPY . .
8 WORKDIR /src/host/Demo.ProductManager.HttpApi.Host
9 RUN dotnet restore -nowarn:msb3202,nu1503
10 RUN dotnet build --no-restore -c Release -o /app
11
12 FROM build AS publish
13 RUN dotnet publish --no-restore -c Release -o /app
14
15 FROM base AS final
16 WORKDIR /app
17 COPY --from=publish /app .
18 ENTRYPOINT ["dotnet", "Demo.ProductManager.HttpApi.Host.dll"]
这里需要注意第3行端口号和我们定义的服务端口号一致,第8行WORKDIR中/src后面的路径是启动项相对于Dockerfile所在目录的路径,第18行的dll为启动项的dll文件。
Demo中其他项目Dockerfile内容格式和此项目一致。
3. Jenkins配置
在Jenkins主菜单点击“New Item”创建单个服务发布流程
输入项目名称为productmanager并选择“Freestyle project”并点击“确定”。
在源代码管理中选择Git并在Repository URL处配置源代码git地址,这里我使用Demo在Gitee中的地址:https://gitee.com/lightnehum/abp-microservice-demo
如果GIt地址需要用户名密码,则在Credentials选项卡中点击添加,输入用户名密码并选择此项。
在“构建”选项卡中点击“增加构建步骤”,并选择“Build/Publish Docker Image”。
在Directory for Dockerfile输入框中输入:
/var/jenkins_home/workspace/productmanager/src/service/productmanager
此地址是Dockerfile在Jenkins容器中的地址,其中/var/jenkins_home/workspace为固定目录,productmanager为Jenkins地址,后面为启动项所在目录(Dockerfile所在目录)相对于总项目目录的地址。
“Cloud”选择我们在第一章节中配置的“Docker”。
这里我使用阿里云提供的免费镜像仓库,登录阿里云控制台,进入容器镜像服务,在实例列表中选择个人实例。
在仓库管理→命名空间中添加自己的命名空间。
在仓库管理→镜像仓库中添加镜像仓库名称为projectmanager,命名空间选择刚才创建的命名空间,仓库类型选择私有,点击“下一步”,代码源选择“本地仓库”,并点击“创建镜像仓库”。
创建完成后在仓库的基本信息中找到公网地址,并将内容复制到Jenkins之前步骤“构建”选项卡的Image输入框中。
继续编辑Jenkins“构建”选项卡,在Registry Credentials选项中,我们需要添加并选择阿里云镜像仓库的用户名密码。
将选项卡中的复选框:Push image、Clean local images、Attempt to remove images when jenkins deletes the run、Disable caching、Pull base image全部勾选。
点击保存完成Jenkins中产品管理服务发布配置。
点击“立即构建”可从git中拉取代码并将产品管理服务推送到阿里云镜像仓库。
其他服务可依照相同方法创建Jenkins发布流程将镜像推送至镜像仓库。
ABP vNext微服务架构详细教程——镜像推送的更多相关文章
- [Abp vNext微服务实践] - 添加中文语言
简介 abp vNext中提供了多语言功能,默认语言是英文,没有提供中文语言包.在业务开发中,定义权限后需要用中文的备注提供角色选择,本篇将介绍如何在abp vNext中加入中文语言. step1:添 ...
- [Abp vNext微服务实践] - 文章目录
简介 ABP vNext是volosoft的新一代框架,ABP(vNext)完全使用.NET CORE和DDD(领域驱动)打造,目前GitHub已有6K+次提交,发布版本超过40次,Nuget包下载量 ...
- [Abp vNext微服务实践] - 服务通讯
简介 服务通讯是微服务架构中必不可少的功能,服务通讯的效率决定了微服务架构的优略.常用的微服务通讯策略有两种,分别是rpc.http,其中rpc以gRpc框架为代表使用者最多.abp vNext微服务 ...
- 基于 abp vNext 微服务开发的敏捷应用构建平台 - 项目介绍
缘起 目前使用ABP框架已经将近3年了,大大小小的项目也陆陆续续做了很多.由于现有信息系统的架构模式是在底层的技术平台上直接构建信息系统并采用技术主导,使用业务无关的编程工具来开发信息系统的缺陷使得系 ...
- [Abp vNext微服务实践] - 启动流程
前几篇分别介绍了abp vNext微服务框架和微服务CI/CD环境搭建,本篇开始介绍vNext微服务框架的开发环境搭建. 环境准备 官方介绍的系统架构图如下: 上图中身份服务和网关服务已经集成在系统中 ...
- [Abp vNext微服务实践] - 业务开发
前几篇分别介绍了abp vNext微服务框架.开发环境搭建和vue element admin前端框架接入,在vue element admin中实现用户角色管理基本功能后就可以开始进行业务开发了,本 ...
- [Abp vNext微服务实践] - 前后端分类
一.前景 abp vNext是ABP 开源 Web应用程序框架,是abp的新一代开源web框架.框架完美的集成.net core.identity server4等开源框架,适用于构建web应用程序和 ...
- abp vNext微服务框架分析
本文转载自:https://www.cnblogs.com/william-xu/p/11245738.html abp vNext新框架的热度一直都很高,于是最近上手将vNext的微服务Demo做了 ...
- [Abp vNext微服务实践] - 框架分析
一.简介 abp vNext新框架的热度一直都很高,于是最近上手将vNext的微服务Demo做了一番研究.我的体验是,vNext的微服务架构确实比较成熟,但是十分难以上手,对于没有微服务开发经验的.n ...
- [Abp vNext微服务实践] - 租户登录
简介 Abp vNext微服务授权验证基于ids4,实现租户登录需要在授权服务中获取token,和之前的介绍的登录方式一样,只是多了tenant参数.本篇将介绍在Abp vNext授权服务中启用多租户 ...
随机推荐
- vuex状态管理器
vuex核心概念 // vuex中一共有五个状态 State Getter Mutation Action Module import Vue from 'vue' import Vuex from ...
- 测试elasticsearch保存时报找不到类型的错误
java测试存储数据到es时报错:...ActionRequestValidationException: Validation Failed: 1: type is missing... /** * ...
- Mysql数据库基础第二章:(十)联合查询
Mysql数据库基础系列 软件下载地址 提取码:7v7u 数据下载地址 提取码:e6p9 mysql数据库基础第一章:(一)数据库基本概念 mysql数据库基础第一章:(二)mysql环境搭建 mys ...
- crontab执行不生效
背景:不知道什么原因脚本手动执行:正常:crontab执行不生效: 1.将命令所属路径加入到 /etc/crontab中, 2.在shell脚本中加入 source /etc/profile
- 使用vue3在element plus中在el-table中拖拽
1.安装 vuedraggable npm i -S vuedraggable 2.在使用的组件,引入.sortablejs包含在vuedraggable import Sortable from & ...
- LVS+keepalived实现负载均衡&高可用(原来以及部署方法)
一.ARP技术概念介绍 为什么讲ARP技术,因为平常工作中有接触.还有就是LVS的dr模式是用到arp的技术和数据. 1.什么是ARP协议 ARP协议全程地址解析协议(AddressResolutio ...
- JS篇(010)-JavaScript 继承的方式和优缺点
答案:六种方式 一.原型链继承 缺点: 引用类型的属性被所有实例共享 在创建 Child 的实例时,不能向 Parent 传参 二.借用构造函数(经典继承) 优点: 避免了引用类型的属性被所有实例共享 ...
- vue 动态路由添加的问题
vue3中在router/index.js中 import { createRouter, createWebHistory } from 'vue-router'; import store fro ...
- ftp服务无法覆盖同名文件
1.linux修改/etc/pure-ftpd/pure-ftpd.conf的AutoRename yes 重启ftp服务 2.windows server修改 选中ftp站点,选择右侧高级设置,选 ...
- js-3part-Javascript使用Ajax
getElementsByName使用方法如下是input标签,我们尝试从里面获取到csrf的value值. 这个csrf标签,是隐藏的,在浏览器页面element可以看到,在html源码里面,是看不 ...