全球今头条!中国、美国和欧盟等主要谈判参加方完成《服务贸易国内规制参考文件》国内核准程序
商务部今天(18日)消息,12月16日,世贸组织举行服务贸易国内规制联合声明倡议谈判大使级会议,包括中国、美国、欧盟在内的55个参加方宣布完
部署了一个免费的 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 的第二个分身上线了!
关键词:
商务部今天(18日)消息,12月16日,世贸组织举行服务贸易国内规制联合声明倡议谈判大使级会议,包括中国、美国、欧盟在内的55个参加方宣布完
出境游搜索猛增,中国人想去海外哪里旅游?撰文|林秋艺编辑|龚正随着国内防疫规定的进一步调整,民众出境旅游、探亲、进行实地商务开展的动力
中国质量新闻网讯12月15日,江苏省苏州市市场监管局网站发布2022年船用燃料油产品质量市级监督抽查情况(第57期)。本次抽查20批次船用燃料油
今日亚洲时段重要数据回顾:08:01英国12月Gfk消费者信心指数前值-44,公布值-42总部位于德国纽伦堡的GfK集团,有着80年的发展历史,日前拥有超过50
劳动合同到期终止,劳动合同自动延续。双方同意续约的,用人单位在终止之日一个月之内应当与劳动者订立书面劳动合同。满一个月不满一年,不与
(1)、标准:为48个月至60个月的统筹地区上年度职工月平均工资(2)、要求:第一、伤残职工停工留薪期内因工伤导致死亡的其直系亲属享受本条
上证50股指期权将于2022年12月19日正式挂牌交易。中国金融期货交易所相关负责人表示,上证50股指期权上市后,可以和上证50股指期货、上证50ETF
北京日报客户端|记者刘苏雅12月15日,中国工程院院刊《Engineering》发布“2022全球十大工程成就”,包括北斗卫星导航系统、嫦娥探月工程、新
正邦科技:关于向下修正可转换公司债券转股价格的公告
2022年,南召县、方城县、社旗县三县通过联合执法对区域内白酒市场进行专项整治,抽调三县执法骨干成立酒类市场专项整治工作领导小组,各县综
丰原药业(000153)12月14日在投资者关系平台上答复了投资者关心的问题。投资者:董秘:您好,请问贵司有无针对防疫政策增加生产?客户有没有加
央视网消息:近日网络流传,一种名为BQ 1 1的新型变异毒株已经出现。中国疾控中心12月13日表示,BQ 1是奥密克戎BA 5在人群流行传播过程中,通
作为年底最重磅的大片,《阿凡达2:水之道》即将在12月14日全球上映,导演卡梅隆最近也飞遍全球宣传电影,不过即将在洛杉矶举行的美国首映礼他
1、产生罚息这是金钱上的损失。如果信用贷款出现逾期,贷款机构会先电话催收贷款,提醒借款人还款,同时利率还会上浮,作为每天的罚息。虽然每
证券代码:603880 证券简称:南卫股份 公告编号:2022-061 江苏南方卫材医药股份有
根据市场公开信息整理,12月12日中文在线(300364)新增【数据要素】概念。新增概念原因:公司业务覆盖版权确权服务,基于公司自研的区块链使
截至2022年12月9日收盘,华菱精工(603356)报收于15 22元,下跌2 44%,换手率1 18%,成交量1 58万手,成交额2436 96万元。12月
特一药业(002728)11月30日在投资者关系平台上答复了投资者关心的问题。投资者:公司有投资房地产吗特一药业董秘:您好,感谢您对公司的关注!
2022年12月7日森鹰窗业(301227)发布公告称公司于2022年12月1日接受机构调研,东北证券轻工分析师唐凯陈渊文、长江养老保险、招商信诺资产、西部
如今对于笔记本电脑的应用环境与数年前完全不同,数年前的笔记本电脑由于体积庞大可以说是大门不出二门不迈的大家闺秀,而今天的笔记本电脑
近两年的显示行业,Mini LED的火爆程度大家有目共睹,从平板、到笔记本再到电视,各大行业头部品牌纷纷加入了Mini LED阵营。
3月15日晚,央视315晚会报道了软件下载平台“高速下载”陷阱的问题。记者在PC6下载站、桔梗下载站、腾牛网、ZOL软件下载等平台下载软件时都出现类似的问题。
AMD近日正式发布了3D V-Cache缓存堆叠版的锐龙7 5800X3D,拥有4MB二级缓存、32MB三级缓存、64MB外置缓存,合计达100MB,号称可击败i9-12900K,重夺最强游戏处理器称号。
Intel在欧洲地区的投资规模不亚于美国本土的投资计划,而且涉及范围更多,美国本土主要是半导体制造及研发,欧洲地区还有先进封装技术。
一直以来,微信PC版因为始终没有添加好友的功能而被用户吐槽,对上班族来说,想要添加好友,还要拿起手机操作,十分不便。