当前位置:首页>新闻 > >正文

Free Arch: 将 IdentityServer 部署到 Okteto

  • 2022-12-20 13:41:04来源:
最终成果

部署了一个免费的 IdentityServer 实例: https://id6-jeff-tian.cloud.okteto.net/


(资料图片)

相关代码提交

一共 3 个,以这个为主:

https://github.com/Jeff-Tian/IdentityServer/commit/b40e6c6f8e4193ef459ab558a102f84442b3cede

前情提要

早在《身份验证哪家强?Identity Server 初体验》中,就部署了一个免费的 IdentityServer 实例,托管在 Azure 上: https://id6.azurewebsites.net/。

后来,我宣称 Free Arch 要狡兔三窟,多处部署:《Free Arch: 狡兔三窟,多处部署》。今天,就来给 IdentityServer 这个实例,添加一个分身,从此不局限于 Azure 平台。就详述一下部署将它部署到 Okteto 的步骤。由于采用了 OAM,不需要太多工作,就能参考前文,将它部署到 Napptive 等任何 Kubernetes 集群里。

第一步,容器化

这是一个 ASP.NET Core 项目,从官方的开源仓库 fork 过来后做了一些魔改,源代码在: https://github.com/Jeff-Tian/IdentityServer。其 Dockerfile 如下:

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS baseWORKDIR /appEXPOSE 5000EXPOSE 5001FROM mcr.microsoft.com/dotnet/sdk:6.0 AS buildWORKDIR /srcCOPY . .RUN dotnet restore "hosts/main/Host.Main.csproj"RUN dotnet build hosts/main/Host.Main.csproj -c Release -o /app/buildFROM build AS publishRUN dotnet publish hosts/main/Host.Main.csproj -c Release -o /app/publishFROM base AS finalWORKDIR /appCOPY --from=publish /app/publish .ENTRYPOINT ["dotnet", "Host.Main.dll"]

第二步,构建镜像并上传至 Docker Registry

为了能够自动在 github actions 的 cicd 过程中自动进行这一步,我们把手动执行的命令放在一个文件里: .github/ci.sh。这一步的提交见:

https://github.com/Jeff-Tian/IdentityServer/commit/3db4235f5e091cda1d2752a8f61df5a9fddbd2b4。

docker build -t jefftian/id6 .docker imagesdocker run --network host -e CI=true -d -p 127.0.0.1:5000:5000 --name id6 jefftian/id6docker ps | grep -q id6docker ps -aqf "name=id6"docker push jefftian/id6docker logs $(docker ps -aqf "name=id6$")curl localhost:5000 || docker logs $(docker ps -aqf "name=id6$")docker kill id6 || echo "id6 killed"docker rm id6 || echo "id6 removed"

第三步,准备数据库

本 IdentityServer 使用了 PostgreSQL 数据库。如何拥有一个免费的 PostgreSQL 数据库服务?如果喜欢自己部署,仍然可以利用 Okteto,参考:《Free Arch: 在 Okteto 上部署 backstage (第一部分: PostgreSQL)》。

当然,也可以使用别人部署好的免费 PostgreSQL 服务,比如 app.nhost.io 提供的服务就不错。

为了验证数据库连接正常,本 IdenityServer 只是连接了数据库,并且执行了一个空的 EF Migration,在本地使用 docker compose 验证了成功执行了 Migration:

这个 docker compose 文件如下:

version: "3"services:postgres:image: "postgres"ports:- "5432:5432"environment:POSTGRES_DB: id6POSTGRES_USER: postgresPOSTGRES_PASSWORD: nopwdvolumes:- pg:/var/lib/postgresql/dataadminer:image: library/adminer:latestrestart: alwaysports:- 7777:8080volumes:pg: ~

由于依赖了数据库,在本地运行本 IdentityServer 实例,需要:

docker compose up -ddotnet run --project hosts/main/Host.Main.csproj

最终部署后,它会在线上的数据库里也创建出一个 __EFMigrationHistory 表,如果是使用了 app.nhost.io 的服务,可以使用其提供的 Hasura 验证:

第四步,加密敏感信息

这就是前面提到的主要的提交。再一次使用了 SOPS,对 SOPS 步骤的详细介绍参考《[Free Arch: 在 Okteto 上部署 backstage(第二部分) - Jeff Tian的文章 - 知乎 ](https://zhuanlan.zhihu.com/p/590640020) 》。要使用它,需要在项目根目录添加一个 .sops.yaml文件:

creation_rules:# If assuming roles for another account use "arn+role_arn".# See Advanced usage- path_regex: k8s\/app\/secrets\.yaml$kms: "arn:aws:kms:us-east-1:443862765029:key/b1739688-ec15-407d-895d-d05ca1217a2f"aws_profile: lambda-doc-rotary

在 k8s/app/secrets.yaml添加数据库连接信息:

apiVersion: v1kind: Secretmetadata:name: id6labels:branch: maintype: OpaquestringData:DatabaseHost: xxxDatabasePort: "5432"DatabaseUser: postgresDatabasePassword: yyyDatabaseName: zzz

第五步,添加 k8s 相关的描述文件

这一步,基本上和《[Free Arch: 在 Okteto 上部署 backstage(第二部分) - Jeff Tian的文章 - 知乎](https://zhuanlan.zhihu.com/p/590640020) 》相同。一个显著不同的是在开启 Ingress 这里,这次没有使用自动 Ingress,而是专门添加了一个 Ingress.yaml 描述文件:

apiVersion: networking.k8s.io/v1kind: Ingressmetadata:name: id6annotations:dev.okteto.com/generate-host: id6spec:rules:- http:paths:- backend:service:name: id6port:number: 80path: /pathType: ImplementationSpecific

这一点在那篇文章有提及,但这次算是真的补上了这个公开示例。

相比上文,其他的改进点在 deployment.yaml 文件中添加了 replicas,并指定了 2,使得同时有 2 个 pod 运行。

其他文件略过,在此不表。最终需要在 .github/workflows 文件夹下添加一个 cicd 的描述文件:

name: cicdon:push:branches: [ "main" ]pull_request:branches: [ "main" ]schedule:- cron: "0 */12 * * *"jobs:deploy-okteto:runs-on: ubuntu-latestneeds: buildsteps:- uses: actions/checkout@v3- run: curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl- run: chmod +x ./kubectl- run: sudo mv ./kubectl /usr/local/bin/kubectl- run: mkdir ${HOME}/.kube&&mkdir ${HOME}/.aws- run: npm i -g k8ss- run: echo -e "machine github.com\n  login ${{secrets.GH_TOKEN}}" > ~/.netrc- run: echo -e "[lambda-doc-rotary]\naws_access_key_id = ${{secrets.AWS_ACCESS_KEY}}\naws_secret_access_key = ${{secrets.AWS_SECRET_KEY}}\n" > ~/.aws/config- run: wget https://github.com/mozilla/sops/releases/download/v3.7.3/sops-v3.7.3.linux.amd64- run: sudo cp sops-v3.7.3.linux.amd64 /usr/local/bin/sops- run: sudo chmod +x /usr/local/bin/sops- run: git clone https://github.com/Jeff-Tian/k8s-config.git ${HOME}/k8s-config- run: k8ss switch --cluster=okteto --namespace=jeff-tian- run: sops -d k8s/app/secrets.yaml --aws-profile lambda-doc-rotary | kubectl apply -f -- run: kubectl apply -k k8s/app&&kubectl rollout restart deploy id6build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v3- run: echo "${{secrets.DOCKER_PASSWORD}}" | docker login -u "${{secrets.DOCKER_USERNAME}}" --password-stdin- run: sh .github/ci.sh

注意在这个文件里,依赖了多个环境变量,这需要添加在 github 代码仓库的 secrets 里:

第六步,没有第六步了!

提交代码,等待 Actions 跑完:

IdentityServer 的第二个分身上线了!

标签:

延伸阅读

推荐阅读

世界最资讯丨金水区南阳路街道开展“心理电影沙龙第二期--选择善良,感受奇迹”活动

中原网讯(记者于露刘梦琳通讯员李学莉汤永浩)电影是浓缩的艺术表现形式

微软更新基于 Win11 22H2 的验证操作系统 Validation OS|每日消息

根据微软自己的说法:MicrosoftValidationOS是一种轻量级、快速且可自

年薪超75万 A股200亿龙头实控人被留置 股价“20cm”跌停!同行电话也被打爆 涉事公司回应:我们也不清楚状况

又有A股公司实控人被留置。7月3日早盘,国内医疗健康信息化解决方案的

长沙至岳阳旅游价格是多少钱

一、长沙至岳阳旅游价格是多少钱坐高铁出发的话,从长沙南到岳阳东是30

邦彦技术(688132):该股换手率大于8%(07-03)-环球新消息

摘要:2023年07月03日邦彦技术(688132)换手率大于8%,主力资金净流出

世界热头条丨卡通车简笔画图片大全(卡通车简笔画)

你们好,最近小活发现有诸多的小伙伴们对于卡通车简笔画图片大全,卡通

天天播报:吉林市养殖什么手续(吉林省养殖政策2023年)

吉林市养殖的手续流程吉林市养殖的手续流程包括以下几个步骤:申请人需

今日四川省养老金上调2023最新方案公布了吗?2023年四川养老金调整方案预估新消息

2023年四川养老金上调方案今日还未公布。自2023年5月22日人社部下发202

右侧锁骨骨折算几级伤残_锁骨骨折算几级伤残

1、你好。2、如果是自己弄伤的话没有等级的如果是工伤的话也没有等级的

国际快递哪个公司最便宜_国际快递有哪些公司比较便宜

1、国际快递有很多,国内主流的有DHL UPS TNT 易起运等等很多的。2、哪

三亚旅游推介会走进成都

6月29日至7月2日,三亚市旅游发展局连续第4年来到成都,面向旅业和市民

外媒:以色列将从美国购买25架F35战机_新视野

据美联社报导,以色列国防部7月2日宣布,以色列将从美国购买25架F-35战

2023杭州中考第二批录取分数线公布

2023杭州中考第二批录取分数线公布第一批最低录取控制分数线为511分。

噩耗!江苏豪门大佬去世,“父子内斗”落幕_天天百事通

噩耗突然传来。 胡德霖突然离世,或许意味着,江苏豪门“父子内斗”落

在线绘制流程图网站_在线流程图制作网站 要闻

1、迅捷流程图制作软件就可以在线画流程图,而且在线画流程图的方法有

环球观热点:护航“夜经济” 守住群众舌尖安全

图为6月30日,该局幸福监管所检查人员对食品进行抽查。食品安全无小事

一家公司13个沿街门店全部参加晚报发起的“关爱 从一杯水开始”公益活动|世界微速讯

“我们公司13个沿街门店全部参加晚报发起的‘关爱从一杯水开始’公益活

环球短讯!中央气象台发布暴雨蓝色预警 11省区市将现大到暴雨

中央气象台7月3日06时继续发布暴雨蓝色预警:预计,7月3日08时至4日08

文言文全解一本通_当前速递

1、《文言文全解一本通》是2020年山东人民出版社出版的图书,作者是梁

中国置业投资(00736)提前终止上海物业的租赁协议

中国置业投资(00736)发布公告,于2020年6月1日,公司全资附属公司上海祥宸

3日机构强推买入 6股极度低估

歌力思  小而美的多品牌时装集团逆势拓张彰显信心  东北证券6月30

罗塞夫:共识与合作需得到急迫且系统遵循|环球时讯

  中评社北京7月3日电(记者 李子宁 海涵 助理记者 徐媛 赵海欣

当前热点-习言道|第一身份是共产党员,第一职责是为党工作

7月1日是党的生日。党员是党的肌体的细胞,如何做一名合格的共产党员?

气液增压泵 关于气液增压泵介绍

1、气液增压泵工作原理类似于压力增压器,对大径空气驱动活塞施加一个

【环球新要闻】汽车开窗的秘密(科研版)

本文讨论的话题是汽车的开窗通风。本文基于CFD对小轿车在不同开窗情况

(新时代 新征程 新伟业·乡村振兴在路上)定西:大力培育乡村技能人才 赋能乡村全面振兴 天天播资讯

定西市始终把大力培育乡村工匠、发展庭院经济作为人才振兴、产业振兴的

环球观焦点:织密群众脚下安全网 镇平县圆满完成窨井盖整治年度任务

大河网讯小井盖,大民生。自2021年河南省城市公共区域窨井盖专项整治三

深交所中止审核新强联收购圣久锻件51%股权事项 世界实时

7月2日,新强联公告,因财务资料过期,深交所中止审核新强联拟收购洛阳

赛季两次杀进大满贯半决赛,萨卡里成希腊一姐

据悉,在萨卡里之前,唯一进入过女单世界前20的希腊女球员是埃莱尼·达

猜您喜欢

Copyright ©  2015-2032 潇湘服装网版权所有  备案号:琼ICP备2022009675号-41   联系邮箱: 435 227 67@qq.com