同步操作将从 jumpserver/jumpserver 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#!/usr/bin/env python3# coding: utf-8import argparseimport loggingimport logging.handlersimport osimport sysimport timeimport djangofrom django.core import managementfrom django.db.utils import OperationalErrorBASE_DIR = os.path.dirname(os.path.abspath(__file__))APP_DIR = os.path.join(BASE_DIR, 'apps')os.chdir(APP_DIR)sys.path.insert(0, APP_DIR)os.environ.setdefault("DJANGO_SETTINGS_MODULE", "jumpserver.settings")django.setup()logging.basicConfig(level=logging.DEBUG, format="%(asctime)s %(message)s", datefmt="%Y-%m-%d %H:%M:%S")try:from jumpserver import const__version__ = const.VERSIONexcept ImportError as e:print("Not found __version__: {}".format(e))print("Python is: ")logging.info(sys.executable)__version__ = 'Unknown'sys.exit(1)try:from jumpserver.const import CONFIGfrom common.utils.file import download_filefrom common.utils import make_dirsexcept ImportError as e:print("Import error: {}".format(e))print("Could not find config file, `cp config_example.yml config.yml`")sys.exit(1)os.environ["PYTHONIOENCODING"] = "UTF-8"logging.basicConfig(format='%(asctime)s %(message)s', level=logging.INFO,datefmt='%Y-%m-%d %H:%M:%S')logger = logging.getLogger()try:make_dirs(os.path.join(BASE_DIR, "data", "static"))make_dirs(os.path.join(BASE_DIR, "data", "media"))except:passdef check_database_connection():for i in range(60):logging.info(f"Check database connection: {i}")try:management.call_command('check', '--database', 'default')logging.info("Database connect success")returnexcept OperationalError:logging.info('Database not setup, retry')except Exception as exc:logging.error('Unexpect error occur: {}'.format(str(exc)))time.sleep(1)logging.error("Connection database failed, exit")sys.exit(10)def expire_caches():try:management.call_command('expire_caches')except:passdef perform_db_migrate():logging.info("Check database structure change ...")logging.info("Migrate model change to database ...")try:management.call_command('migrate')except Exception:logging.error('Perform migrate failed, exit', exc_info=True)sys.exit(11)def collect_static():logging.info("Collect static files")try:management.call_command('collectstatic', '--no-input', '-c', verbosity=0, interactive=False)logging.info("Collect static files done")except:passdef compile_i18n_file():django_mo_file = os.path.join(BASE_DIR, 'apps', 'locale', 'zh', 'LC_MESSAGES', 'django.mo')if os.path.exists(django_mo_file):returnos.chdir(os.path.join(BASE_DIR, 'apps'))management.call_command('compilemessages', verbosity=0, interactive=False)logging.info("Compile i18n files done")def download_ip_db():db_base_dir = os.path.join(APP_DIR, 'common', 'utils', 'ip')db_path_url_mapper = {('geoip', 'GeoLite2-City.mmdb'): 'https://jms-pkg.oss-cn-beijing.aliyuncs.com/ip/GeoLite2-City.mmdb',('ipip', 'ipipfree.ipdb'): 'https://jms-pkg.oss-cn-beijing.aliyuncs.com/ip/ipipfree.ipdb'}for p, src in db_path_url_mapper.items():path = os.path.join(db_base_dir, *p)if os.path.isfile(path) and os.path.getsize(path) > 1000:continueprint("Download ip db: {}".format(path))download_file(src, path)def install_builtin_applets():logging.info("Install builtin applets")try:management.call_command('install_builtin_applets', verbosity=0)except Exception as e:logging.error("Install builtin applets err: {}".format(e))def upgrade_db():collect_static()perform_db_migrate()def prepare():check_database_connection()upgrade_db()expire_caches()download_ip_db()install_builtin_applets()def start_services():services = args.services if isinstance(args.services, list) else [args.services]if action == 'start' and {'all', 'web'} & set(services):prepare()start_args = []if args.daemon:start_args.append('--daemon')if args.worker:start_args.extend(['--worker', str(args.worker)])if args.force:start_args.append('--force')try:management.call_command(action, *services, *start_args)except KeyboardInterrupt:logging.info('Cancel ...')time.sleep(2)except Exception as exc:logging.error("Start service error {}: {}".format(services, exc))time.sleep(2)if __name__ == '__main__':parser = argparse.ArgumentParser(description="""Jumpserver service control tools;Example: \r\n%(prog)s start all -d;""")parser.add_argument('action', type=str,choices=("start", "stop", "restart", "status", "upgrade_db", "collect_static"),help="Action to run")parser.add_argument("services", type=str, default='all', nargs="*",choices=("all", "web", "task"),help="The service to start",)parser.add_argument('-d', '--daemon', nargs="?", const=True)parser.add_argument('-w', '--worker', type=int, nargs="?")parser.add_argument('-f', '--force', nargs="?", const=True)args = parser.parse_args()action = args.actionif action == "upgrade_db":upgrade_db()elif action == "collect_static":collect_static()else:start_services()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。