当前位置:首页>热门 > >正文

Free Arch: 将 IdentityServer 部署到 Okteto:时讯

  • 2022-12-21 17:44:27来源:
最终成果

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

标签:

延伸阅读

推荐阅读

Free Arch: 将 IdentityServer 部署到 Okteto:时讯

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

惠程科技:回购注销限制性股票276万股:快看点

作者:木木2022年12月20日,惠程科技发布了关于部分限制性股票回购注销完成的公告。从中可以看到:公司本次回购注销涉及原激励对象11名,回购

贵州电力告急:为何连续两年跳入同一个“坑”?

谁也未曾料到,在经历了水电大省四川、云南先后两轮缺电后,进入2022年最后一个月,电力结构以火电为主的贵州,居然爆发了缺电危机。华夏能源

汽车“降碳”,有啥新招?|天天热头条

文、图 广州日报全媒体记者邓莉  虽然今年车市遭遇各种波折,但新能源汽车继续一路高歌。李明桓表示,主机厂探索碳中和之路,落地两个方向,

业务流程建模,细到几层?

​在我做的BDF框架中,业务建模是非常重要的一个能力之一。因为有了建模能力,就可以提供面向于不同目标用户的可解释能力了。这种可解释能力可

观察:太平石化金租员工利用职务便利与他人违规经济往来,1人遭终身禁业

太平石化金租员工利用职务便利与他人违规经济往来,1人遭终身禁业

方大炭素最新公告:发行GDR并在瑞士证券交易所上市获得瑞士证券交易所监管局附条件批复_天天新要闻

方大炭素公告,公司于近日收到瑞士证券交易所监管局关于公司发行全球存托凭证(GDR)并在瑞士证券交易所上市的附条件批准,瑞士证券交易所监管

【手慢无】销量百万爆款!联想红点鼠标白菜价28.8元

只要你是中国人,我相信这个鼠标你绝对不可能没见过,有时候去银行或者是企业经常看见用的都是这款联想的大红点鼠标,经典的外观设计和结实耐

舞阳:市场监管局审批窗口为企业办实事 高效服务获点赞_每日观点

近年来,舞阳县市场监督管理局审批窗口立行政审批职能,进一步突出“靠前一步、主动握手”理念,变被动审批为主动服务,精准研判办事需求,...

全球快讯:附注的主要审查内容有哪些

附注的主要审查内容只要有四个,包括会计政策、会计估计变更和会计差错更正的审查、或有事项的审查、资产负债表日后事项审查和关联方关系及其

印度成功试射“烈火-5”型洲际弹道导弹

当地时间12月15日,印度在奥里萨邦外海的卡兰岛(AbdulKalamIsland)成功进行了可携带核弹头的“烈火-5”型洲际弹道导弹的夜间飞行试验。15日

每日热闻!菜放冰箱两天还能吃吗 菜放冰箱两天可以吃吗

1、蔬菜放在冰箱内一般是可以吃的,第二天吃不会有变质的现象,但是一般不要经常吃隔夜的菜,避免出现有亚硝酸盐有致癌性。2、建议:平时最好

环球滚动:海利生物: 海利生物关于董事辞职的公告

海利生物:海利生物关于董事辞职的公告

快报:张伯礼:一二月份后疫情或迎春暖花开,不会出现大规模感染

在2023环球时报年会生命健康分论坛上,张伯礼表示,目前疫情形势发生了很大变化,应以变应变,我国防控政策也是按照这个逻辑在不断优化调整。

万华、中石化加速布局百万吨级乙烯及下游项目!

万华120万吨 年乙烯及下游高端聚烯烃项目12月13日晚间,万华化学发布对外投资公告,投资标的名称:万华化学120万吨 年乙烯及下游高端聚烯烃项

新华都(002264)12月15日主力资金净卖出568.75万元

截至2022年12月15日收盘,新华都(002264)报收于6 1元,下跌2 87%,换手率1 7%,成交量10 47万手,成交额6444 86万元。

全球快消息!央行15日开展6500亿元中期借贷便利操作 中标利率2.75%

中新网12月15日电 据央行网站15日消息,为维护银行体系流动性合理

原轼新材已完成财务资料更新:河北省专精特新企业,公司业绩整体快速增长:今日最新

张家口原轼新型材料股份有限公司于12月14日更新上市申请审核动态,因发行人已完成财务资料更新,根据相关规定,本所恢复其发行上市审核。  

法治副校长工作不能仅仅“盯”着孩子!:全球最新

大河网讯“今年有没有新进教职工?入职查询有没有做到位?是否建立档案?强制报告制度各位老师是否了解?”近日,在嵩县第二实验小学法治工...

世卫组织:全球累计新冠确诊病例达645630482例

世卫组织:全球累计新冠确诊病例达645630482例2022年12月14日07:55中国政府网

崧盛股份(301002.SZ):崧盛投资减持期过半 已减持103.93万股-天天热闻

格隆汇12月13日丨崧盛股份公布,近日公司收到持股5%以上股东出具的告知函,截至2022年12月13日,崧盛投资本次减持计划的减持时间已过半,其已

中环装备董秘回复:公司供暖设备暂无出口 环球观点

中环装备(300140)12月13日在投资者关系平台上答复了投资者关心的问题。

兆龙互连: 关于召开2022年第二次临时股东大会的通知_全球资讯

证券代码:300913      证券简称:兆龙互连          公告编号:2022-061              浙江兆龙互连科技股份

工信部通告三季度电信服务质量情况
全国电信用户申诉率同比下降51.7%_热点

日前,工业和信息化部通告2022年第三季度电信服务质量情况。2022年第三季度电信服务重点工作有序开展。一是着力提升信息通信服务水平。组织全

龙洲股份: 关于2023年度为控股子公司提供担保预计的公告

证券代码:002682   证券简称:龙洲股份    公告编号:2022-067           龙洲集团股份有限公司   本公司及董事会全体

世界通讯!益盛药业董秘回复:公司的原材料里主要为人参,目前公司没有以红景天为原料的产品

益盛药业(002566)12月09日在投资者关系平台上答复了投资者关心的问题。投资者:请问贵公司的原材料红景天大概是多少益盛药业董秘:您好,公司

全球焦点!亚太药业(002370)12月7日主力资金净卖出1014.81万元

截至2022年12月7日收盘,亚太药业(002370)报收于5 54元,上涨3 17%,换手率12 46%,成交量61 82万手,成交额3 38亿元。12月7日

天天快讯:科兴制药: 首次公开发行战略配售限售股上市流通公告

证券代码:688136          证券简称:科兴制药              公告编号:2022-061                

猜您喜欢

Copyright ©  2015-2022 热讯服装网版权所有  备案号:豫ICP备20005723号-6   联系邮箱:29 59 11 57 8@qq.com