forked from TencentBlueKing/bk-nodeman
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
sprintfix: 进程启动优化 (closed TencentBlueKing#1369)
- Loading branch information
1 parent
854bbe2
commit 36736b9
Showing
5 changed files
with
66 additions
and
58 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
62 changes: 62 additions & 0 deletions
62
apps/node_man/management/commands/fetch_component_api_public_key.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
# coding: utf-8 | ||
""" | ||
TencentBlueKing is pleased to support the open source community by making 蓝鲸智云-节点管理(BlueKing-BK-NODEMAN) available. | ||
Copyright (C) 2017-2022 THL A29 Limited, a Tencent company. All rights reserved. | ||
Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License. | ||
You may obtain a copy of the License at https://opensource.org/licenses/MIT | ||
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on | ||
an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the | ||
specific language governing permissions and limitations under the License. | ||
""" | ||
|
||
|
||
from apigw_manager.apigw.helper import PublicKeyManager | ||
from blueapps.utils.esbclient import get_client_by_user | ||
from django.conf import settings | ||
from django.core.management import call_command | ||
from django.core.management.base import BaseCommand | ||
|
||
from common.log import logger | ||
from env import constants as env_constants | ||
|
||
|
||
class Command(BaseCommand): | ||
""" | ||
拉取 ESB / APIGW 公钥 | ||
这块不放在 apps init 中,减少进程启动数据,防止容器化部署情况下,Probe 探针在 app 未就绪情况下探活失败引起容器反复重启 | ||
依赖 migrate 后执行 | ||
""" | ||
|
||
def handle(self, **kwargs): | ||
|
||
# 当环境整体使用 APIGW 时,尝试通过 apigw-manager 获取 esb & apigw 公钥 | ||
if settings.BKPAAS_MAJOR_VERSION == env_constants.BkPaaSVersion.V3.value: | ||
|
||
for component_name in ["esb", "apigw"]: | ||
try: | ||
call_command(f"fetch_{component_name}_public_key") | ||
except Exception: | ||
logger.info(f"[JWT][{component_name.upper()}] fetch {component_name} public key error") | ||
else: | ||
logger.info(f"[JWT][{component_name.upper()}] fetch {component_name} public key success") | ||
|
||
client = get_client_by_user(user_or_username=settings.SYSTEM_USE_API_ACCOUNT) | ||
esb_result = client.esb.get_api_public_key() | ||
if not esb_result["result"]: | ||
logger.error(f'[ESB][JWT] get esb api public key error:{esb_result["message"]}') | ||
return | ||
|
||
api_public_key = esb_result["data"]["public_key"] | ||
# esb-ieod-clouds / bk-esb / apigw 为各个环境的约定值,由 ESB 调用时解析 jwt header 的 kid 属性获取 | ||
# Refer:site-packages/apigw_manager/apigw/providers.py | ||
if settings.RUN_VER == "ieod": | ||
# ieod 环境需要额外注入 esb 公钥,从而支持 ESB & APIGW | ||
PublicKeyManager().set("esb-ieod-clouds", api_public_key) | ||
logger.info("[JWT] get esb public key and save to esb-ieod-clouds") | ||
elif settings.BKPAAS_MAJOR_VERSION != env_constants.BkPaaSVersion.V3.value: | ||
# V2 环境没有 APIGW,手动注入 | ||
PublicKeyManager().set("bk-esb", api_public_key) | ||
PublicKeyManager().set("apigw", api_public_key) | ||
logger.info("[JWT] get esb public key and save to bk-esb & apigw") | ||
|
||
logger.info("[JWT] fetch component api public key success.") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
#!/bin/bash | ||
python manage.py createcachetable django_cache | ||
python manage.py migrate | ||
python manage.py fetch_component_api_public_key |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,5 @@ | ||
#!/bin/bash | ||
python manage.py createcachetable django_cache | ||
python manage.py migrate | ||
python manage.py fetch_component_api_public_key | ||
python manage.py copy_file_to_nginx |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
#!/bin/bash | ||
python manage.py createcachetable django_cache | ||
python manage.py migrate | ||
python manage.py fetch_component_api_public_key | ||
python manage.py copy_file_to_nginx |