实时

您的位置:首页>产品 >

Free Arch: 将 IdentityServer 部署到 Okteto-环球快资讯

最终成果

部署了一个免费的 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 的第二个分身上线了!

关键词:

推荐阅读
最终成果部署了一个免费的IdentityServer实例:https: id6-jeff-tian cloud okteto net 相关代码提交一共

2022-12-19 19:00:06

证券时报记者沈宁  日前,期货市场再传大消息——螺纹钢期权、白银期权获批12月26日在上期所上市。就在螺纹钢期权和白银期权之前,12月已有

2022-12-19 14:08:56

(原标题:北上资金连续六周净流入,持续看好大消费板块,这些高人气股获资金抢筹)近一月,传媒、家电、社会服务、食品饮料等大消费板块持续

2022-12-19 08:15:06

消防宣传进社区,安全知识暖人心---极目新闻通讯员舒美琪。为进一步增强社区居民的消防安全意识,普及消防安全知识,近日,湖北省襄阳市消防救

2022-12-18 22:14:02

1、牛蛙本身属于一种蛙类,体内含有很多的细菌和寄生虫。如果想要吃牛蛙,一般建议最少高温烹饪一个小时以上,才可以杀灭牛蛙体内的寄生虫。2

2022-12-18 04:25:38

12月16日消息,今日,一则“女子发烧敷20分钟面膜揭下变3D立体”的话题登上微博热搜,引起网友热议。不过,玩笑归玩笑,发烧的时候最好还是不

2022-12-17 09:46:04

全省新增正高级工艺美术师3名、副高级18名,涉及石木雕、陶艺、传统服饰等专业类别。

2022-12-16 19:13:50

康普顿(603798)12月16日在投资者关系平台上答复了投资者关心的问题。

2022-12-16 13:50:26

12月14日晚,江西省抚州市崇仁县公安局发布警情通报。2022年12月12日上午9时50分许,崇仁县公安局巴山派出所接辖区群众报警求助称:陈某某(女,16岁

2022-12-16 07:31:50

一般在北京上海广东等一线城市都贵。臀部抽脂后做一个5mm的小切口,所以我现在准备做臀部抽脂。价格是多少?不同城市吸脂价格不一样。根据你的

2022-12-15 19:00:54

手没有锐角镀金和弯曲的情况下,精钢固体镀金的手,RADO,雷达,不到1500元,假手表粗糙和时尚,适合男孩。而且正反面的字都很清楚。挺好的。

2022-12-15 13:47:22

嘉实中证主要消费ETF净值上涨1 87%请保持关注

2022-12-15 07:18:13

大河报·豫视频记者侯冰玉近日,农业农村部办公厅、共青团中央办公厅、全国少工委办公室联合公布了首批60个农耕文化实践营地推荐名单,河南省

2022-12-14 16:27:24

众所周知,自“双碳目标”提出以来,清洁能源并被视为行业发展大风口。而氢能作为全球能源向可持续发展转型的主要路径之一,发展潜力亦不容小

2022-12-14 11:17:51

《陪你一起长大》上星,《大宋宫词》将播,刘涛双剧来袭强势霸屏这些年,随着《琅琊榜》《芈月传》《欢乐颂》等剧的热播,刘涛再度翻红,摘掉

2022-12-13 23:25:08

北京时间12月13日,2022年哥伦比亚举重世锦赛在波哥大继续进行。在女子71公斤级比赛中,中国军团再传捷报,再次收获1金2银1铜。廖桂芳以140公

2022-12-13 14:29:09

根据市场公开信息及12月12日披露的机构调研信息,长城基金近期对3家上市公司进行了调研,相关名单如下:1)邦彦技术(证券之星综合指标:1 5星

2022-12-13 07:37:11

消费者打开天猫超市,搜索“碳足迹”就可以直接购买该系列商品,包含一次性纸杯、纸盘、竹筷、烘焙纸和便携内裤。“碳足迹”系列商品上线之后

2022-12-12 17:27:04

据央视新闻,国家税务总局12月12日发布的数据显示,今年前十个月,个体工商户享受减税降费3285亿元,预计全年4300亿元左右。随着“六税两费”

2022-12-12 13:15:39

证券代码:603113      证券简称:金能科技          公告编号:2022-156      债券代码:113545      债券简称:金能转

2022-12-09 19:07:13