前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >生产环境隐藏敏感配置信息方案

生产环境隐藏敏感配置信息方案

作者头像
小闫同学啊
发布2020-03-25 12:07:40
1.1K0
发布2020-03-25 12:07:40
举报
文章被收录于专栏:小闫笔记小闫笔记

项目上线时需要切换生产环境配置信息,这些信息可以直接被保存在项目中吗?如果保存下来,不小心提交到仓库或被破解查看,生产环境岂不是裸奔?那么该如何解决?更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

1.演示环境

本文以 Flask 项目为例说明,简单环境信息:

1) Flask + Flask-RESTful

2) CentOS

2.方案

一般配置信息都保存在指定目录下,分为测试、开发以及生产。其中测试与开发配置文件的保留,问题不大,关键就是生产环境配置信息如何处理。

1) 可以在 .gitignore 文件中添加忽略文件,使其不被提交到仓库。

虽然不在仓库内,但是配置文件仍然在项目中

2) 可以通过添加环境变量的方式解决。推荐指数5颗星 ~

3.方案实施

可以保留项目中开发(测试)环境配置文件,将需要修改的数据库配置项等单独在生产环境配置文件中重写,并配置环境变量(生产配置文件路径)。然后在项目加载默认配置信息后,通过环境变量引入生产配置信息,从而覆盖掉无用配置,隐藏敏感信息。这样我们的生产信息既不在仓库内,也不在项目中,而是在服务器某个角落。项目中的配置信息都是本地配置项,被人知道也无妨,保留后还能造成迷惑。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

3.1 在服务器任意目录下存放生产环境配置信息

生产配置文件 app_deploy.py 中既可以保存 MySQLRedisElasticsearch 数据库集群信息,还可以保存私钥等敏感信息。

比如我们将其存放在如下路径:

代码语言:javascript
复制
/root/config/app_deploy.py

3.2 配置环境变量

在部署项目的 shell 脚本中添加如下信息:

代码语言:javascript
复制
export TOUTIAO_APP_SETTING=/root/config/app_deploy.py

3.3 设置常量保存环境变量名

在项目如下文件中:

代码语言:javascript
复制
.../common/utils/constants.py

添加常量信息:

代码语言:javascript
复制
GLOBAL_SETTING_ENV_NAME = 'TOUTIAO_APP_SETTING'

3.4 在项目初始化文件中加载环境变量

代码语言:javascript
复制
from flask import Flask


def create_flask_app(config, enable_config_file=False):
    """
    创建 Flask 应用
    :param config: 配置信息对象
    :param enable_config_file: 是否允许运行环境中的配置文件覆盖已加载的配置信息
    :return: Flask 应用
    """
    app = Flask(__name__)
    app.config.from_object(config)
    if enable_config_file:
        from utils import constants
        app.config.from_envvar(constants.GLOBAL_SETTING_ENV_NAME, silent=True)

    return app

以上只是本人在实际项目中的一个小应用,可以类比去设置 Django 项目。当然,如果你有更好方法可以后台给小闫留言,不胜感激。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-03-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈技术精选 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.演示环境
  • 2.方案
  • 3.方案实施
    • 3.1 在服务器任意目录下存放生产环境配置信息
      • 3.2 配置环境变量
        • 3.3 设置常量保存环境变量名
          • 3.4 在项目初始化文件中加载环境变量
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档