【焦点热闻】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温网大幕开启,OPPO专业影像实力见证赛场精彩时刻_焦点滚动
- 江苏三条过江通道建设有新进展 崇启公铁长江大桥北主塔桩基全部完成 环球新视野
- 滁州学院与琅琊区合作交流会暨校政企研签约仪式举行
- 美味扇贝处理技巧大揭秘!|全球速递
- 没有离职证明可以提取公积金吗
- 老年子宫内膜息肉怎么治疗(子宫内膜息肉怎么治疗) 当前视点
- 环球热资讯!大学录取通知书里,藏着这些中国式浪漫
- 中年打鼾怎么治疗_打鼾怎么治疗_天天热闻
- 滚动:上海大学2023级研究生新生缴费办法
- 世界短讯!关于征求省标《福建省居住建筑节能设计标准》(征求意见稿)意见的通知
- b2c网站有哪些营销策略(b2c网站有哪些) 全球头条
- 世界热文:世界周刊丨美国“毒”病难有尽头
- 快资讯:现代讽刺的韩国诗
- 观点:耳麦没有声音但是可以说话(耳麦没声音怎么办)
- 华纺股份(600448):7月3日技术指标出现看涨信号-“红三兵” 全球热文
- 每日动态!机构观点:美豆油涨停 国内棕榈油预计大幅拉升
- “小而美”的家庭托育点如何不负所“托”? 环球今日讯
- 索尼紧凑型数码相机市场份额急速下降 已从第一跌至第七
- win7需要administer的权限才能删除(win7需要administrator权限才能删除) 环球热消息
- 全球头条:浑南区教育局为少年举办成长礼
- 世界观点:银行股上半年涨跌参半,分红方案近期纷纷出炉
- 苹果怎么查询序列号入口_苹果怎么查询序列号_全球时讯
- iqooneo8pro怎么样值得买吗(iqoo neo 5和iqoo 7哪个下巴窄点) 世界讯息
- 枣庄封闭式初中学校有哪些 枣庄封闭式初中学校都有哪些_环球新消息
- 焦点播报:柯基被砍伤事件 砍死柯基男子被警方带走调查 基本情况讲解
- 内蒙古:算力产业绿色降碳 “绿电”使用率达58%左右|全球播报
- 郑州植得口腔医院收费贵不贵?口碑、坐诊大夫在线咨询!-天天快播报
- 传承红色基因 赓续红色血脉!常宁各界开展“七一”庆祝活动
- 朝鲜小“网红”介绍平壤,韩政府以“宣传朝鲜体制”为由屏蔽,谷歌跟风封号
- 冀凯股份:上半年预计亏损1600万元–2100万元
- 擤鼻子出血怎么治_擤鼻子出血怎么回事 今日热讯
- 法国连续第5夜发生骚乱:719人被捕 骚乱者驾车撞入官员家中
- 草原天路文化旅游提档升级
- 今年以来我国高温日数创历史新高,北方高温多次叠加实属罕见|全球即时看
- 大运会火炬“蓉火”今天开始在成都市内传递
- 佛系、躺平与内卷
- 热点评!民调数据中的美国:岌岌可危
- 环球热文:从“00”后到“80”后,“全职儿女”们的背后:只是暂停不是“躺平”
- 天天关注:四会富仕:公司产品应用于工业控制领域占比约60% 主要应用于马达、传感器等
- 2023年暑运正式开启 预计发送旅客7115万人次 环球快资讯
- 今日热讯:2022 年一级造价工程师《建设工程技术与计量(土木建筑工程)》考前模拟卷一单项选择题44
- 【快看】辽宁省抗美援朝精神研究基地在辽东学院揭牌
- 青山什么裹尸还(青山处处何须马革裹尸的意思)
- 当前热议!科创板IPO半年报:募资877亿领先全A 其中48%为半导体
- 交易型诈骗犯罪中“被害人财产损失”应予分类判断-焦点报道
- 等闲识得东风面万紫千红总是春是什么意思 这句诗译文介绍 世界动态
- 无锡滨湖重磅推出优化营商环境5.0版政策
- 下水管被水泥堵住了怎么疏通_下水管被水泥堵住了怎么办
- 人人皆可斗气化翼,白小纯危险等级攀升,外出历练之路开启
- 焦点!自主择业军转论坛网_全国自主择业军转干部管理服务工作平台
- 买笛子哪个调的比较好 买笛子哪个牌子好
- 校园鬼故事小说_关于校园鬼故事小说概略
- 【世界聚看点】把好计量"小关口" 切实服务"大民生"
- 职工困难户申请书范文(困难户申请书范文)
X 关闭
最新资讯
- 各地开展活动庆祝中国共产党成立102周年
- 天天要闻:你们我们他们 电视剧_你们我们他们
- 新能源行业重磅!“光伏茅”猛降硅片价格
- 金沙江流域水电工程劳动竞赛总结表彰大会暨金沙江清洁能源走廊建设劳动竞赛启动会召开_焦点观察
- 推动乡村文化振兴 江苏省书法院在溧水打造“书法乡村” 天天新动态
- 视频|历史一刻,首辆香港单牌车顺利驶入内地|全球新资讯
- 【全球快播报】癌症骨转移患者还能活多久啊_癌症骨转移患者还能活多久
- 杨兰英(关于杨兰英的简介)
- 对话尼山——“文明”上“网”
- 教育部和各地各高校积极行动 助力毕业生求职圆梦 速读
- 当前时讯:宝宝 最爱吃饭――0-3岁婴幼儿辅食添加全程制作方案
- 鸡小龙_关于鸡小龙简述
- 国城矿业:投资建设基础锂盐项目 每日看点
- 榴莲什么好处(榴莲的作用有哪些)
- 宝马3系18寸标准胎压是多少正常(宝马3系18寸标准胎压是多少?)
- 创造新模式、多方齐发力 美丽经济在山谷中绽放
- 厦门国贸10亿元超短债完成发行,发行利率2.23%|当前通讯
- 天天快报!游客注意!北京多家市属公园游船停航
- 如何去掉仪表盘上的小扳手图标_热文
- 栗赏木_关于栗赏木概略
- 成都到重庆火车票 重庆火车票_聚看点
- 深中华B6月30日盘中跌幅达5%
- 国内首次,北京4万余株古树名木体检“全覆盖”
- 机构:预计苹果Vision Pro头显上市后第五年用户将达2000万
- 环球焦点!世界即时看!离岸人民币(CNH)兑美元北京时间04:59报7.2686元 天天短讯
- 酒驾40多公里,从安徽到盱眙讨债,结果被欠债的举报了-全球微速讯
- 全球视点!6月29日基金净值:富国高质量混合最新净值0.7732,跌0.88%
- 焦点关注:cf是啥?(cf是什么意思游戏)
- 勒夏特列和楞次定律_勒夏特列
- 《国韵·匠心》视觉设计“礼”有型,“乐”有象-全球新视野
- 快讯2023-06-30 04:28:18
- 无痕_关于无痕介绍-世界新要闻
- LV总裁成都太古里出行,不仅挡路还不让拍照引热议! 当前焦点
- 2023年深圳(上海)外商投资促进交流会在沪举办
- 北江纺织IPO“终止” 公司产品包括牛仔面料、其他面料、服装
- 首批体育支教志愿者结束支教生活,“以学定教”为当地体育教学播下一颗种子 每日讯息
- 全球微资讯!多维康集团_康维多官网
- 第五届“新时代中国大讲堂”举行结业仪式 世界报道
- 雾道车灯几线品牌_vland车灯是什么品牌
- 栖林寺访德清法师_关于栖林寺访德清法师概略
- 世界今亮点!迪丽热巴与陈伟霆甜蜜浪漫相约 从古剑奇谭到奔跑吧
- 环球消息!95人上榜!榆林中院发布第34批失信被执行人名单
- 一场3比2让国足形势大好,满足3条件就提前出线,最差是打平晋级_当前通讯
- 世界观速讯丨中国北方十城市经济优势解析及发展建议
- 曝女模特脱下鞋扔向评委,怒吼:你个流氓,昨晚说好让我当冠军-今日视点
- 福州航空开展“茉莉”示范组进校园活动-环球聚焦
- 环球短讯!山西一煤矿发生顶板事故 已有3人获救 仍有1人被困
- 金通灵突遭立案,前期曾公告会计差错更正,股民可索赔-天天热点
- 全国多地地铁列车推分区控温,“强冷”“弱冷”车厢差2℃|当前热议
- 自然资源部发布2022年度全国矿产资源储量统计数据 中国石油六座油气田新增储量规模升级“大型” 环球热门
X 关闭