部署了一个免费的 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 的第二个分身上线了!
关键词:
-
德外长访问哈尔科夫期间承诺再提供武器|环球头条
来源:俄罗斯卫星通讯社俄罗斯卫星通讯社柏林1月10日电德国外交部网站发布的声明称,德国外交部长安娜莱娜•贝尔伯克在对哈尔科夫进行的访问期
-
澳门新马路春节变身步行街喜迎福兔 全球新资讯
人民网澳门1月10日电(记者富子梅)记者从澳门特区文化局了解到,往日车水马龙的澳门半岛新马路,兔年春节期间将变身步行街,推出崭新城市项目
-
其他电源设备板块1月10日跌0.23%,龙源技术领跌,主力资金净流出9351.57万元 天天快看点
1月10日其他电源设备板块较上一交易日下跌0 23%,龙源技术领跌。当日上证指数报收于3169 51,下跌0 21%。深证成指报收于11506 79,上涨0 49%。
-
赞美手指甲的句子(精选409句) 环球观天下
赞美手指甲的句子精选65句1 长年累月地操劳,这双手已粗糙得像老松树皮,手背裂开了一道道口子,手掌也磨出了厚厚的茧子。2 辞旧岁,迎新春,
-
全球快资讯:通胀“破4” 经济低迷 日本货币宽松行至“十字路口”
1月10日,日本内务省公布数据显示,日本东京通胀率自1982年以来首次达到4%。至此,日本东京通胀率同比增幅已连续9个月高于2%的目标。东京的通
-
广东机场集团诞生首个“数字员工”|每日关注
(记者郭军)随着集团数字财务平台上线试运行,广东机场集团首个数字员工于新年第一天加入员工大家庭,正式成为该机场集团的一名员工。由于数字
-
今日热搜:高盛:维持比亚迪电子(00285)“买入”评级 目标价升至28.35港元
高盛上调比亚迪电子(00285)2023年每股盈利预测至1 49元人民币。
-
车e贷贷款逾期七年多久会上征信系统
网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可
-
环球视讯!益盛药业:公司的主导产品振源胶囊和心悦胶囊均可用于冠心病、心绞痛的治疗
同花顺(300033)金融研究中心1月10日讯,有投资者向益盛药业(002566)(002566)提问,请问,贵公司是否生产治疗心血管疾病的药,如治疗冠状动脉
-
每日简讯:植物奶板块1月9日涨0.52%,承德露露领涨,主力资金净流出1.67亿元
1月9日植物奶板块较上一交易日上涨0 52%,承德露露领涨。当日上证指数报收于3176 08,上涨0 58%。深证成指报收于11450 15,上涨0 72%。植物奶
-
翼龙贷网贷逾期29天不还会不会上征信
网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可
-
全球微动态丨“照片里的2022”获奖名单公布,新一年你我继续砥砺前行!
糖酒快讯发起“图片里的2022”征集活动以来,一共收到335人次的共计685张参选图片,经过糖酒快讯编辑部筛选评定,正式
-
焦点资讯:双鸭山九级工伤赔偿标准如何认定
职工因工致残被鉴定为七级至十级伤残的,享受以下待遇:(一)从工伤保险基金按伤残等级支付一次性伤残补助金,标准为:七级伤残为13个月的本
-
【独家】留给威马的时间不多了
“让威马从神坛上跌落的不是外人:脾气最火爆的侯海靖妄图只手遮天;最懂销售的陆斌背锅离开;CEO沈晖酿出一系列骚操作。每走错一步棋,都将威
-
为期40天 2023年春运1月7日日正式开启 每日消息
央视网消息:昨天(1月7日),2023年春运正式开启。铁路、道路运输、民航等部门采取多种举措,在做好疫情防控工作的同时,强化春运服务和安全
-
峭岐怎么读 峭岐的读音介绍|当前快播
1、峭岐:[qiàoqí]。2、地处美丽富饶的太湖之畔,位于文明港城江阴市腹地,北距江阴市中心12公里,域内面积48平方公里,人口近5万。3、该镇
-
未办理施工许可手续便开工建设 青城建工集团被罚款5000元|焦点快看
青城建工集团有限公司施工的一处项目中,土石方和支护工程存在未办理施工许可手续便开工建设的问题,该公司因此被青岛市住房和城乡建设局处以
-
全球要闻:盐田港集团2022年旗下盐田港区等共完成集装箱吞吐量1630.13万标箱
证券时报e公司讯,据盐田港集团官方微信公众号,2022年1-12月,盐田港集团旗下盐田港区、大铲湾港区、小漠港区共完成集装箱吞吐量1630 13万标
-
今年大雪到冬至怎么只有14天? 环球快看
我们的祖先把中国的一年时间和天文地理气候相结合,凭着多年的日积月累经验总结出结论,就是一年十二个月,相对应的是有二十四个节气。每一个
-
特斯拉上海被曝停产一周,股票暴跌,到底发生什么了?
最近听到一句话,新冠阴性快清零了。其实特斯拉的股票……也快清零了。01—特斯拉股价暴跌12月27日,也就是圣诞节过去仅仅两天,特斯拉股价暴