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 的第二个分身上线了!
标签:
相关文章
Free Arch: 将 IdentityServer 部署到 Okteto:当前滚动
最终成果部署了一个免费的IdentityServer实例:https: id6-jeff-tian cloud okteto net 相关代码提交一共
江苏阳光: 江苏阳光股份有限公司关于召开2022年第四次临时股东大会的提示性公告_世界报道
江苏阳光:江苏阳光股份有限公司关于召开2022年第四次临时股东大会的提示性公告
讲解百科 白色污染主要指什么
白色污染主要指:用聚苯乙烯、聚丙烯、聚氯乙烯等高分子化合物制成的包装袋、农用地膜、一次性餐具、塑料瓶等塑料制品使用后被弃置成为固体
科普知识 vac是什么气体
vac是醋酸燃烧产生的气体。醋酸一种有机一元酸,为食醋主要成分。纯的无水乙酸(冰醋酸)是无色的吸湿性固体,凝固点为16 6℃(62℉),凝固后
知识库 涛涛不绝还是滔滔不绝哪个正确
词语滔滔不绝出自五代·后唐·王仁裕《开元天宝遗事·走丸之辩》,用流水不断之意,指说话一张嘴就没有尽头,形容说话连续不断口才好。释义...
如何评价大连理工大学樊鑫老师
最佳答案曾在大连海事大学信息工程学院任讲师,从2006年5月至2009年6月分别在美国俄克拉荷马州立大学和德州大学西南医学研究中心进行博士后
知识大全 雪诺为什么能复活
《权力的游戏》中雪诺是被红袍女复活的,按照红袍女的话说,是光之王的意志让他活了下来。雪诺复活后,守夜人的誓言将不再是他的负担,所以
知识领域 关于沈阳工业大学辽阳校区
沈阳工业大学辽阳校区:沈阳工业大学辽阳分校是沈阳工业大学位于辽阳市的分校。 始建于1978年,校名为辽阳化纤工学院。1984年6月,学校划
知识探索 求面积换算公式体积换算公式
常用的面积单位有公顷、亩、平方公里、平方米、平方厘米等。这里所说的换算,常指面积之间单位的互换计算。常用土地面积换算公式:1亩等于6
百科大全 神兵玄奇的内容介绍
《神兵玄奇》是香港武侠漫画宗师黄玉郎所着的畅销之作。《神兵玄奇》至今总共出版了13部,其中科幻纪停刊,神兵F清末篇共14回,已完结,神
百科全书 艾戈勒手表怎么样
艾戈勒是瑞士知名钟表品牌,其秉承着历史传承和崇高设计理念,精湛工艺,巨细摩遗,考究审慎。凭借强大的机芯、创新的理念、精致的做工及完
知识智库 苏州大秋裤叫什么
东方之门,俗称秋裤楼,被誉为世界第一门,设计师是汪大绥,位于中国江苏省苏州市,总高度为301 8米。总投资金额达45亿元,已于2015年8月最
百科词典 如何提高语言表达能力
1、锻炼自己的胆量,不要放过那些可以发言的机会,多到经常开会的主席台上,面对下面练习发言,在开会讲话的时候,不要直视下面的人;2、明
“对话十城专精特新小巨人”——红星资本局联合工信部中小企业发展促进中心系列报道正式启动_微动态
中小企业是保市场主体、保就业的主力军。中小企业走专精特新发展道路已经成为近年来我国中小企业发展的一个鲜明特征。
小米贷款网贷逾期二天延迟还款会上征信系统吗
网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可
借呗逾期6个月多久上征信系统
网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可
塞浦路斯议长:塞中关系取得新进展
据新华网报道,塞浦路斯议长迪米特里乌14日在中国驻塞浦路斯大使馆举办的纪念中塞建立战略伙伴关系一周年和建交51周年招待会上表示,塞中关系
中国铁建拟市场化债转股 对四家全资子公司增资100亿元
央企市场化债转股再下一城。12月16日晚间,中国铁建发布公告称,为降低公司下属4家全资子公司中铁十四局、中铁十八局、中铁二十局和中铁城建的
全球时讯:一新冠患者因过量饮水导致水中毒 感冒喝水有什么作用
我们都知道在生病的时候多喝水有利于病情的恢复的,但是最近有一新冠患者因为过量饮水导致出现水中毒的现象,这是怎么一回事?感冒的时候喝水
南京雨花石细支怎么辨别真假 请看回答-聚焦
1 看烫金的区别:烟盒正面的“南京”二字方方正正,饱满顺滑;假烟盒正面“南京”字样模糊,字体漏金溢出明显。2 看印刷区别:烟盒正面的龙...
建发物业(02156)授出合共705万股限制性股份
智通财经APP讯,建发物业发布公告,于2022年12月15日,该公司董事会已批准根据激励计划向集团不超过105名雇员授出合共705万股限制性股份,惟须
天马新材(838971)12月15日游资资金净卖出14.02万元:环球速读
截至2022年12月15日收盘,天马新材(838971)报收于17 78元,上涨0 97%,换手率0 24%,成交量0 04万手,成交额72 51万元。
世界热议:非工伤死亡单位有哪些赔偿?能否公司一定要经济补偿的?
员工非工伤死亡,公司要给该员工的家属丧葬费、一次性救济金,还要供养直系亲属生活困难补助。根据相关法律的规定,公司要给该员工的亲属下列
聚焦:上工申贝(600843.SH)拟推2022年员工持股计划、规模不超575.2878万股
格隆汇12月14日丨上工申贝发布2022年员工持股计划(草案),本次员工持股计划涉及的标的股票规模不超过575 2878万股,不超过公司股本总数的0 81%
全球球精选!高效有序!洛龙区完成全员核酸首轮检测
大河网讯5月4日,洛龙区新冠肺炎疫情防控指挥部发布通告,于2022年5月5日和5月8日在全区开展2轮全员核酸检测。截至5日15时,洛龙区本轮全员核
广东昨日新增本土确诊1013例、本土无症状1817例:天天速讯
12月13日0-24时,全省新增本土确诊病例1013例(广州533例,深圳83例,珠海14例,汕头69例,佛山23例,韶关11例,河源10例,梅州6例,惠州33
网贷逾期14000还不上会有什么后果?|天天热文
1、产生罚息这是金钱上的损失。如果信用贷款出现逾期,贷款机构会先电话催收贷款,提醒借款人还款,同时利率还会上浮,作为每天的罚息。虽然每