【焦点热闻】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 的第二个分身上线了!
标签:
推荐文章
- 雷神众测漏洞周报2023.1.3-2023.1.8
- 苹果AR头显春季发:原型机在测试了!
- 每日信息:美芝股份: 第四届董事会第二十三次会议决议公告
- 景区积极谋划 抓住冬季旅游“窗口期”拉动消费|全球观速讯
- 华夏航空客服回应航班取消:因飞机故障原因导致
- 战风霜 甘平淡 守安宁——访内蒙古出入境边防检查总站呼伦贝尔边境管理支队北屯边境派出所
- 平安惠普借款逾期18年延迟还款会不会上征信|全球通讯
- 丰立智能:公司部分产品可应用于工业机器人_天天要闻
- 中教控股(00839.HK)拟先旧后新配售最多1.47亿股 净筹15.98亿港元
- 质押贷逾期31年还不起征信会怎么样
- 天天热点!普大笑了!中国10万吨巨型船坞已抵达,为俄航母量身定制!
- 陆金贷(大额专享)逾期29天多久会上征信系统
- 优酷过冬,禁止“白嫖” 焦点热讯
- 【世界播资讯】新闻特写:回家的感觉真好
- 【天天热闻】猫眼怎么安装 猫眼的安装方法介绍
- 【全球热闻】瑞昌查获一“翻新机”网店!涉案240余万元
- 环球速递!若羽臣(003010.SZ):晨晖盛景方面累计减持1.02%股份、合计持股比例降至5%以下
- 全切双眼皮17天,右眼不消肿?7.5mm宽吗?
- 2022 年终总结
- [快讯]雷柏科技:关于控股股东减持达到1%暨减持计划实施完毕
- 联诚协会 | 助推创新创业 撬动创业梦想
- 江门城乡医保门诊能报销吗? 快资讯
- 全球观速讯丨郑州沥青路面常见病害的维修与养护措施
- “最帅中国演员”榜单出炉,杨洋、吴磊上榜前五,肖战拿下首位!|环球今头条
- 苏泊尔(002032)1月4日主力资金净买入412.93万元
- 本人人身损害赔偿款能否继承 环球速读
- 2023年考cfa一级应该看什么教材?有什么备考建议?
- 热讯:消费者权益保护新规来了,禁止误导性宣传、强制捆绑搭售
- 石家庄:男子跨年狂欢喝大酒 元旦下午醉驾被查_世界要闻
- 1月3日基金净值:招商品质升级混合A最新净值0.8144,涨1.14%
- 安博通(688168.SH):崚盛投资完成减持1%股份
- 【独家焦点】曝赵本山时隔11年回归央视春晚,还有彩排照流出?知情人发声澄清
- 2023年郑州门诊报销政策|焦点日报
- 元旦期间全国社会大局稳定治安秩序良好 全球热消息
- 醋化股份(603968.SH)拟推出2022年股票期权与限制性股票激励计划 焦点热门
- 环球今亮点!双枪科技(001211)12月30日主力资金净卖出78.55万元
- 青岛食品12月30日快速上涨
- 问需纾困精准施策 RCEP实施近一年海关助企尽享政策红利-世界即时
- 河南苏羊遗址发现300余座龙山时期墓葬 焦点日报
- 全球讯息:红墙股份(002809.SZ)主要股东广东科创已减持1%股份
- 世界观点:记一次QQ找回经历
- 瑞泰科技董秘回复:公司会严格按照要求进行信息披露 焦点短讯
- 俄外长:俄罗斯正在与以美国为首的西方集体交战_全球看热讯
- 博彩公司遭黑客攻击,67000账户被窃,损失超30万!公司称登录信息由第三方泄露
- 【播资讯】威奥股份:董事李世坤增持公司股票约2.9万股
- 禾盛新材12月28日加速下跌
- 年终经济观察|推动高质量发展迈上新台阶 天天关注
- 全球要闻:伊巴卡:帕金斯为了流量不要脸 编造杜兰特威少谎言
- 环球观点:鞍重股份: 关于合资公司完成注册登记的公告
- 张家界市教育局关于做好全市中小学期末教学工作的通知
- 昆船智能董秘回复:公司非常重视科技人才的培养和引进,人才资源及技术研发实力是公司蓬勃发展的关键所在|全球微速讯
- 天天热讯:多地推动壮大民营经济 融资支持力度持续加大
- 【世界报资讯】新华全媒+|“三西”巨变40年:从“苦甲天下”到振兴热土
- 董明珠售卖贵价N95口罩?格力:假的!-全球最资讯
X 关闭
最新资讯
- 数字人民币App再更新 互动新功能意在几何-通讯
- 三星医疗(601567.SH)预中标1.73亿元南方电网项目
- 支持开票 | Python实证指标构建与文本分析
- ppmoney逾期9个月会上征信系统吗|天天即时
- 重磅数据二度来袭,黄金 还能挺住吗?-环球聚看点
- 实时焦点:两轮旅行 愉悦骑游赏花城
- 苏宁贷贷款逾期四年上征信吗?多久会上征信
- 11个幽默小短句,哈哈一笑,烦恼全消!
- 天天快资讯丨各地民营企业 积极作为谋发展
- 海南橡胶: 第六届董事会第十七次会议决议公告 世界要闻
- 一系列稳岗政策帮扶 企业用工得到缓解 焦点关注
- 新消息丨怎样操作你我贷逾期9年会上征信系统?
- 中石化加油充值卡的回收平台。 天天观点
- 简讯:重庆钢铁:公司暂未委托价格谈判
- 张伯礼:建议将新冠肺炎概念分为3类,防重症、降死亡
- 【焦点热闻】Free Arch: 将 IdentityServer 部署到 Okteto
- 全球时讯:九典制药董秘回复:最近公司洛索洛芬纳片的销量有较明显的提升,公司正在加大产量,力求能满足市场需求
- 使用 IdentityServer 保护 Vue 前端_全球观速讯
- H5开屏从龟速到闪电,企微是如何做到的 快讯
- 每日视点!美国将结束边境限制 移民数量预计大幅增长
- 全球观点:怎么考取cqf证书?有了证书可以找什么工作?
- 个人养老金资金账户能否变更?福建省人社厅详解热点问题 重点聚焦
- 毅昌科技:公司主营业务为精密模具、注塑零部件、整机等产品的研发、生产和销售
- 中国证监会新闻发言人就中美审计监管合作进展情况答记者问-热议
- 上海吴淞海关支持张华浜码头首次出口新能源车 扩大上海港集聚优势 全球实时
- “惠购湖北”消费券“加更”,今晚8点抢年货券!
- 天天亮点!A股申购 | 纬达光电(873001.BJ)开启申购 主要产品为偏光片 存在产品结构单一风险
- cqf在国内认的人多么?含金量如何?
- 珍宝岛:复方芩兰口服液再入陕西新冠中医药预防方案
- 阿莫西林胶囊哪种好
- 埃索凯子公司环保问题连发,信披矛盾真实性存疑
- 元琛科技(688659)12月12日主力资金净买入980.20万元_实时焦点
- 百利好黄金原油晚盘分析:美元美债有所反弹 金价短期或将承压-全球独家
- 注册会计师发展前景怎么样?含金量有多高?
- 祥和实业: 浙江天台祥和实业股份有限公司关于向激励对象首次授予限制性股票的公告|实时
- 息县人民政府县长管保臣:决守牢不发生规模性返贫底线
- 海泰新光涨6.01%,东吴证券一个月前给出“买入”评级
- 【环球时快讯】步长制药:公司产品宣肺败毒颗粒在《新型冠状病毒肺炎诊疗方案(试行第九版)》中被列为临床治疗期(确诊病例)普通型推荐用药,暂无其他新冠病毒相关药品
- 全国首部!江西“小切口”立法 解决环境大问题
- 邯郸市启动为期半年的食品安全专项行动 严打食品违法犯罪行为
- “洗衣液奶茶”因存安全隐患全部下架 商家:“以后也不会再卖了”
- 警惕“唱反调”演变成不尽责 独董不能止于说“不”更要勤勉尽责
- 恐龙呼吸道感染首个证据发现 几万年前的恐龙也患感冒
- 台风“圆规”携风裹雨来袭 广东深圳、珠海等地停课停工
- 西藏米林“家庭农场”:引领种植产业 助力乡村振兴
- 从东北到西北 他在“军垦第一城”规划着城建未来
- 新疆阿克苏地区库车市发生4.1级地震 震源深度21千米
- 环球影城过山车突然停驶 游客被困十米高
- 新版控烟条例效果如何?禁烟区依然烟熏火燎
- 还在打赏假脸女主播?来看视频“变装秀”
X 关闭