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 的第二个分身上线了!
标签:
精彩推送
哈尔滨:新增新冠肺炎本土确诊病例5例 计划于23日完成全员核酸检测筛查
新华社哈尔滨9月22日电(记者强勇、杨思琪)9月22日,哈尔滨市应对新型冠状病毒感染肺炎疫情工作指挥...
新闻快讯
X 关闭
X 关闭
新闻快讯
- Free Arch: 将 IdentityServer 部署到 Okteto
- 钟丽缇女儿张思捷被说太社会,本尊回应了,嘴巴含着筷子好无奈
- 宝光股份(600379):公司监事辞职及补选监事 天天视讯
- 世界观速讯丨北交所新股申购报告-太湖雪(838262):丝绸文创“新国货”崛起 天猫蚕丝被销量冠军
- 《奔跑吧》收官大作战,还是你心目中的跑男吗?_今日热讯
- 关于羊了个羊的一些用药提示(发烧用药) 世界通讯
- 新华医疗:公司与山东健康医疗集团部分业务具有上下游的产业协同 每日资讯
- 抽调巡察干部“心”体验|快播报
- 林丹领跑!2022深圳南山半马,杨定宏、焦安静双双夺冠! 观察
- 环球播报:黄山胶囊回应是否受托生产连花清瘟:暂无相关考虑
- 今日安阳钢材价格表,安阳几个县区 世界新要闻
- 利通电子(603629.SH):实控人之一邵秋萍自6月27日起已减持1.044%股份-全球快资讯
- 万润股份:公司没有配备光刻机
- 全球今日讯!舆情追踪| 果麦文化:公司股东被中国证券监督管理委员会浙江监管局处罚
- 三元股份:经自查,公司不存在上述情况 世界今热点
- 医学青年说|使用退烧药的这些注意事项,你了解吗?|全球播报
- 当前滚动:前三季净亏损同比增两倍,小康人寿两款产品被叫停对业绩影响几何?|保险
- 每日焦点!同心护未来 检察不缺位
- 中国武夷董秘回复:装配式建筑作为一种新型建造模式,具备较好的环保效益-环球热讯
- 环球时讯:优德精密: 关于召开2022年第二次临时股东大会的通知
- 天天讯息:国家卫健委:昨日新增本土确诊病例2270例,新增本土无症状感染者5181例
- 焦点热议:威胜信息与沙特丝路公司签署生产项目合作备忘录
- 战风雪!保通信!强寒潮里的新疆电信人!
- 缓解居民“发热焦虑”,社区医疗机构大有可为
- 泓博医药董秘回复:公司目前具备提供小分子新冠口服药关键中间体及研究与开发用途原料药的能力|全球观热点
- 鞍重股份(002667)12月7日主力资金净买入7083.99万元 天天百事通
- 达志科技: 独立董事关于第五届董事会第十二次会议相关事项的独立意见
- 【开源证券】南玻A涨停 消费建材企业或将受益
- 今年唐山高新区重点推进产业项目80个 总投资315亿元
- 端午节后重庆两江游市场逐步恢复 日均接待量约3600人次
- 31省份新增确诊病例43例 其中本土病例28例
- 陕西华北黄淮有较强降水过程 热带低压影响海南岛等地
- 神舟十二号重返地球:“天地大搜救”
- 藏身网络平台 非法引流是如何“浇灌”黑灰产的?
- 黑龙江省22日12-24时新增新冠肺炎本土确诊病例3例
- 一大波雨水将至!北京今天白天有分散性阵雨 傍晚起降雨增多
- 久坐、体重大、锻炼少,腰椎间盘突出越来越年轻化
- 妈妈做手术带着26岁残障儿子住院 医院开“特殊病房”
- 清理入侵物种 恢复海岸生态
- 中秋国庆假期接踵而至 金九银十出行有哪些利与防?
- 当摄影遇到漫画,丰收画卷如此之美
- 今日秋分 | 叠翠流金
- “社交牛掰症”有啥牛的?“梗”下的认同焦虑不能忽视
- 待遇跟上了,叫不叫“农民工”又何妨?
- “十一”出游最热门目的地:北京上海成都排前三
- 北京推出5条直达环球度假区定制公交 单人票价16.8元至24元不等
- 放弃月薪过万工作报名参军 大学毕业生圆了空军战士梦
- 笑对人生!80后癌症女孩4年拍500余条短视频“抗癌日记”
- 北京年底所有行政区将引入共享单车 新增“电子围栏”
- 被问恋爱经历、星座、三围……奇葩招聘背后是就业歧视