diff --git a/.gitignore b/.gitignore index afc4301..1609aca 100644 --- a/.gitignore +++ b/.gitignore @@ -7,6 +7,10 @@ .stestr/ *.DS_Store +devstack/files/*.deb +devstack/files/*.deb.* +venv/ + dist build/* venus.egg-info/ diff --git a/MANIFEST.in b/MANIFEST.in index c978a52..dfff7a2 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -3,4 +3,6 @@ include ChangeLog exclude .gitignore exclude .gitreview +recursive-include venus/db/sqlalchemy/migrate_repo * + global-exclude *.pyc diff --git a/devstack/fluentd-conf/filter/00-record_transformer.conf b/devstack/fluentd-conf/filter/00-record_transformer.conf new file mode 100644 index 0000000..2783b78 --- /dev/null +++ b/devstack/fluentd-conf/filter/00-record_transformer.conf @@ -0,0 +1,9 @@ + + @type record_transformer + + Hostname ${hostname} + Logger openstack.${tag_parts[4]} + programname ${tag_parts[5]} + + + diff --git a/devstack/fluentd-conf/filter/01-rewrite.conf.c b/devstack/fluentd-conf/filter/01-rewrite.conf.c new file mode 100644 index 0000000..a71945e --- /dev/null +++ b/devstack/fluentd-conf/filter/01-rewrite.conf.c @@ -0,0 +1,4 @@ + + @type rewrite_tag_filter + capitalize_regex_backreference yes + diff --git a/devstack/fluentd-conf/format/apache_access.conf b/devstack/fluentd-conf/format/apache_access.conf new file mode 100644 index 0000000..c320132 --- /dev/null +++ b/devstack/fluentd-conf/format/apache_access.conf @@ -0,0 +1,10 @@ + + @type parser + reserve_data true + format grok + key_name message + grok_pattern \[%{HTTPDATE:Timestamp}\] "(?:%{WORD:http_method} %{NOTSPACE:http_url}(?: HTTP/%{NUMBER:http_version})?|%{DATA:rawrequest})" %{NUMBER:http_status} (?:\d+|-) + time_key Timestamp + time_format %d/%b/%Y:%H:%M:%S %z + keep_time_key true + diff --git a/devstack/fluentd-conf/format/wsgi_access.conf b/devstack/fluentd-conf/format/wsgi_access.conf new file mode 100644 index 0000000..52367b2 --- /dev/null +++ b/devstack/fluentd-conf/format/wsgi_access.conf @@ -0,0 +1,10 @@ + + @type parser + reserve_data true + format grok + key_name message + grok_pattern %{IPORHOST:clientip} %{HTTPDUSER:ident} %{USER:auth} \[%{HTTPDATE:Timestamp}\] "(?:%{WORD:http_method} %{NOTSPACE:http_url}(?: HTTP/%{NUMBER:http_version})?|%{DATA:rawrequest})" %{NUMBER:http_status} (?:%{NUMBER:http_bytes}|-) (?:%{NUMBER:http_response_time_us}|-) %{QS:referrer} %{QS:agent} + time_key Timestamp + time_format %d/%b/%Y:%H:%M:%S %z + keep_time_key true + diff --git a/devstack/fluentd-conf/input/08-neutron.conf b/devstack/fluentd-conf/input/08-neutron.conf new file mode 100644 index 0000000..a2b998c --- /dev/null +++ b/devstack/fluentd-conf/input/08-neutron.conf @@ -0,0 +1,15 @@ + + @type tail + path /var/log/kolla/neutron/*.log + pos_file /var/run/td-agent/devstack-openstack_neutron.pos + tag devstack + format multiline + format_firstline /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d{3} \d+ \S+ \S+ \[(\S+ req-\S+ \S+ \S+ \S+ \S+ \S+|-)\]/ + format1 /^(?\S+ \S+) (?\d+) (?\S+) (?\S+) (\[(?\S+) (req-(?\S+) (?\S+) (?\S+) (?\S+) (?\S+) (?\S+)|-)\])? (?.*)?$/ + time_key Timestamp + keep_time_key true + time_format %F %T.%L + ignore_repeated_permission_error true + enable_watch_timer false + + diff --git a/devstack/fluentd-conf/input/09-vitrage.conf b/devstack/fluentd-conf/input/09-vitrage.conf new file mode 100644 index 0000000..30bd747 --- /dev/null +++ b/devstack/fluentd-conf/input/09-vitrage.conf @@ -0,0 +1,15 @@ + + @type tail + path /var/log/kolla/vitrage/*.log + pos_file /var/run/td-agent/devstack-openstack_vitrage.pos + tag devstack + format multiline + format_firstline /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d{3} \d+ \S+ \S+ \[(\S+ req-\S+ \S+ \S+ \S+ \S+ \S+|-)\]/ + format1 /^(?\S+ \S+) (?\d+) (?\S+) (?\S+) (\[(?\S+) (req-(?\S+) (?\S+) (?\S+) (?\S+) (?\S+) (?\S+)|-)\])? (?.*)?$/ + time_key Timestamp + keep_time_key true + time_format %F %T.%L + ignore_repeated_permission_error true + enable_watch_timer false + + diff --git a/devstack/fluentd-conf/input/10-keystone.conf b/devstack/fluentd-conf/input/10-keystone.conf new file mode 100644 index 0000000..d970109 --- /dev/null +++ b/devstack/fluentd-conf/input/10-keystone.conf @@ -0,0 +1,15 @@ + + @type tail + path /var/log/kolla/keystone/*.log + pos_file /var/run/td-agent/devstack-openstack_keystone.pos + tag devstack + format multiline + format_firstline /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d{3} \d+ \S+ \S+ \[(\S+ req-\S+ \S+ \S+ \S+ \S+ \S+|-)\]/ + format1 /^(?\S+ \S+) (?\d+) (?\S+) (?\S+) (\[(?\S+) (req-(?\S+) (?\S+) (?\S+) (?\S+) (?\S+) (?\S+)|-)\])? (?.*)?$/ + time_key Timestamp + keep_time_key true + time_format %F %T.%L + ignore_repeated_permission_error true + enable_watch_timer false + + diff --git a/devstack/fluentd-conf/input/11-cinder.conf b/devstack/fluentd-conf/input/11-cinder.conf new file mode 100644 index 0000000..ec1b417 --- /dev/null +++ b/devstack/fluentd-conf/input/11-cinder.conf @@ -0,0 +1,15 @@ + + @type tail + path /var/log/kolla/cinder/*.log + pos_file /var/run/td-agent/devstack-openstack_cinder.pos + tag devstack + format multiline + format_firstline /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}.\d{3} \d+ \S+ \S+ \[(\S+ req-\S+ \S+ \S+ \S+ \S+ \S+|-)\]/ + format1 /^(?\S+ \S+) (?\d+) (?\S+) (?\S+) (\[(?\S+) (req-(?\S+) (?\S+) (?\S+) (?\S+) (?\S+) (?\S+)|-)\])? (?.*)?$/ + time_key Timestamp + keep_time_key true + time_format %F %T.%L + ignore_repeated_permission_error true + enable_watch_timer false + + diff --git a/devstack/fluentd-conf/input/13-syslog.conf b/devstack/fluentd-conf/input/13-syslog.conf new file mode 100644 index 0000000..7e5d365 --- /dev/null +++ b/devstack/fluentd-conf/input/13-syslog.conf @@ -0,0 +1,9 @@ + + @type tail + path /var/log/bootstrap.log,/var/log/btmp,/var/log/syslog + pos_file /var/run/td-agent/devstack-syslog.pos + tag syslog.* + source_hostname_key Hostname + format /^(?.*)$/ + enable_watch_timer false + diff --git a/devstack/fluentd-conf/output/00-local.conf.back b/devstack/fluentd-conf/output/00-local.conf.back new file mode 100644 index 0000000..f705ec5 --- /dev/null +++ b/devstack/fluentd-conf/output/00-local.conf.back @@ -0,0 +1,18 @@ + + @type copy + + type elasticsearch + host localhost + port 9200 + logstash_format true + logstash_prefix slog + buffer_type memory + buffer_chunk_limit 8m + buffer_queue_limit 8 + buffer_queue_full_action drop_oldest_chunk + flush_interval 30s + num_threads 4 + reconnect_on_error true + resurrect_after 5s + + diff --git a/devstack/fluentd-conf/output/01-es.conf b/devstack/fluentd-conf/output/01-es.conf new file mode 100644 index 0000000..516905d --- /dev/null +++ b/devstack/fluentd-conf/output/01-es.conf @@ -0,0 +1,18 @@ + + @type copy + + @type elasticsearch + host localhost + port 9200 + logstash_format true + logstash_prefix flog + buffer_type memory + buffer_chunk_limit 8m + buffer_queue_limit 8 + buffer_queue_full_action drop_oldest_chunk + flush_interval 30s + num_threads 4 + reconnect_on_error true + resurrect_after 5s + + diff --git a/devstack/fluentd-conf/td-agent.conf b/devstack/fluentd-conf/td-agent.conf new file mode 100644 index 0000000..e678e91 --- /dev/null +++ b/devstack/fluentd-conf/td-agent.conf @@ -0,0 +1,5 @@ +@include input/*.conf +@include filter/*.conf +#@include format/*.conf +@include output/*.conf + diff --git a/devstack/plugin.sh b/devstack/plugin.sh new file mode 100644 index 0000000..ec9c950 --- /dev/null +++ b/devstack/plugin.sh @@ -0,0 +1,163 @@ +# plugin.sh - DevStack plugin.sh dispatch script venus + +# Support potential entry-points console scripts in VENV or not +if [[ ${USE_VENV} == True ]]; then + PROJECT_VENV["venus"]=${VENUS_DIR}.venv + VENUS_BIN_DIR=${PROJECT_VENV["venus"]}/bin +else + VENUS_BIN_DIR=$(get_python_exec_prefix) +fi + +FILES=$VENUS_DIR/devstack/files + +function install_venus() { + setup_develop "$VENUS_DIR" openstack + install_fluentd + install_elastic_search +} + +function init_venus() { + venus_create_accounts + + recreate_database venus utf8 + sudo $VENUS_BIN_DIR/venus-manage --config-file=${VENUS_CONF} db sync +} + +function configure_venus() { + # Create venus conf directory + sudo install -d -o $STACK_USER -m 755 $VENUS_CONF_DIR + + # Copy init conf file + sudo cp -R $VENUS_DIR/etc/venus/* $VENUS_CONF_DIR + + iniset $VENUS_CONF keystone_authtoken memcached_servers localhost:11211 + iniset $VENUS_CONF keystone_authtoken username venus + iniset $VENUS_CONF keystone_authtoken password "$ADMIN_PASSWORD" + iniset $VENUS_CONF keystone_authtoken auth_url "http://$HOST_IP/identity" + + iniset $VENUS_CONF DEFAULT my_ip "$HOST_IP" + iniset $VENUS_CONF DEFAULT osapi_venus_listen_port 10010 + + iniset $VENUS_CONF database connection mysql+pymysql://root:"$DATABASE_PASSWORD"@localhost:3306/venus?charset=utf8 + + iniset $VENUS_CONF elasticsearch url http://localhost:9200 +} + +function start_venus() { + run_process venus-api "$VENUS_BIN_DIR/venus-api" +} + +function install_elastic_search() { + echo_summary "install elastic search" + local FLUENTD_SERVICE="elasticsearch.service" + if [[ is_ubuntu ]]; then + install_package openjdk-8-jdk + + ES_VERSION=${ES_VERSION:-5.6.16} + ES_DOWNLOAD_URL=${ES_DOWNLOAD_URL:-https://artifacts.elastic.co/downloads/elasticsearch} + ES_DOWNLOAD_FILE="elasticsearch-$ES_VERSION.deb" + + if [[ ! -f $FILES/$ES_DOWNLOAD_FILE ]]; then + sudo wget --progress=dot:giga -t 2 -c $ES_DOWNLOAD_URL/$ES_DOWNLOAD_FILE -O $FILES/$ES_DOWNLOAD_FILE + if [[ $? -ne 0 ]]; then + die "$ES_DOWNLOAD_FILE could not be downloaded" + fi + fi + + sudo dpkg -i $FILES/$ES_DOWNLOAD_FILE + $SYSTEMCTL daemon-reload + $SYSTEMCTL enable $FLUENTD_SERVICE + $SYSTEMCTL start $FLUENTD_SERVICE + else + exit_distro_not_supported "install elastic search" + fi +} + +function install_fluentd() { + echo_summary "install fluentd" + if [[ is_ubuntu ]]; then + FLUENTD_VERSION=${FLUENTD_VERSION:-4.1.0-1_amd64} + FLUENTD_DOWNLOAD_URL=${FLUENTD_DOWNLOAD_URL:-http://packages.treasuredata.com.s3.amazonaws.com/4/ubuntu/bionic/pool/contrib/t/td-agent} + FLUENTD_DOWNLOAD_FILE="td-agent_$FLUENTD_VERSION.deb" + + if [[ ! -f $FILES/$FLUENTD_DOWNLOAD_FILE ]]; then + sudo wget --progress=dot:giga -t 2 -c $FLUENTD_DOWNLOAD_URL/$FLUENTD_DOWNLOAD_FILE -O $FILES/$FLUENTD_DOWNLOAD_FILE + if [[ $? -ne 0 ]]; then + die "$FLUENTD_DOWNLOAD_FILE could not be downloaded" + fi + fi + + sudo dpkg -i $FILES/$FLUENTD_DOWNLOAD_FILE + else + exit_distro_not_supported "install fluentd" + fi + + # Create log dir + VENUS_LOG_DIR="/var/log/kolla" + sudo install -d -o $STACK_USER -m 777 $VENUS_LOG_DIR + + # Copy fluentd conf + sudo cp -R $VENUS_DIR/devstack/fluentd-conf/* /etc/td-agent + $SYSTEMCTL restart td-agent +} + +function venus_create_accounts() { + create_service_user "venus" +} + +function uninstall_elastic_search() { + local ELASTIC_SEARCH_SERVICE="elasticsearch.service" + $SYSTEMCTL stop $ELASTIC_SEARCH_SERVICE + $SYSTEMCTL disable $ELASTIC_SEARCH_SERVICE + $SYSTEMCTL daemon-reload + sudo dpkg -r elasticsearch +} + +function uninstall_fluentd() { + local FLUENTD_SERVICE="td-agent.service" + $SYSTEMCTL stop $FLUENTD_SERVICE + $SYSTEMCTL disable $FLUENTD_SERVICE + $SYSTEMCTL daemon-reload + sudo dpkg -r td-agent +} + +# check for service enabled +if is_service_enabled venus-api; then + + if [[ "$1" == "stack" && "$2" == "pre-install" ]]; then + # Set up system services + echo_summary "Configuring system services venus" + echo_summary "Welcome to Venus!" + + elif [[ "$1" == "stack" && "$2" == "install" ]]; then + # Perform installation of service source + echo_summary "Installing venus" + install_venus + + elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then + # Configure after the other layer 1 and 2 services have been configured + echo_summary "Configuring venus" + configure_venus + + elif [[ "$1" == "stack" && "$2" == "extra" ]]; then + # Initialize and start the venus service + echo_summary "Initializing venus" + init_venus + start_venus + fi + + if [[ "$1" == "unstack" ]]; then + # Shut down venus services + # no-op + : + fi + + if [[ "$1" == "clean" ]]; then + # Remove state and transient data + # Remember clean.sh first calls unstack.sh + # no-op + uninstall_elastic_search + uninstall_fluentd + sudo rm -rf $VENUS_CONF_DIR + fi +fi diff --git a/devstack/settings b/devstack/settings new file mode 100644 index 0000000..c4e8c82 --- /dev/null +++ b/devstack/settings @@ -0,0 +1,9 @@ +# settings file for venus + +# API Service +enable_service venus-api + +# Default directories +VENUS_DIR=$DEST/venus +VENUS_CONF_DIR=/etc/venus +VENUS_CONF=$VENUS_CONF_DIR/venus.conf \ No newline at end of file diff --git a/etc/venus/venus.conf b/etc/venus/venus.conf index 2cb7405..bc8f762 100644 --- a/etc/venus/venus.conf +++ b/etc/venus/venus.conf @@ -1,37 +1,27 @@ [keystone_authtoken] -memcached_servers = 100.2.30.241:11211,100.2.30.242:11211,100.2.30.243:11211signing_dir = /var/cache/venus -signing_dir = /var/cache/venus -cafile = /opt/stack/data/ca-bundle.pem -project_domain_name = default +project_domain_name = Default project_name = service -user_domain_name = default -password = dTa74mdF29CyGLQvH8RCKAhFPlRd1zHtp2Ai4NGw +user_domain_name = Default +password = secret username = venus -auth_uri = http://100.2.28.240:5000 -auth_url = http://100.2.28.240:35357 -project_domain_id = default -user_domain_id = default +auth_url = http://0.0.0.0/identity auth_type = password [DEFAULT] -transport_url = rabbit://openstack:R8axM8sde8Dq5tV1PcDHmDRPLsA9fBLpXrGQccfE@100.2.30.243:5672 -my_ip = 100.2.30.243 +transport_url = rabbit://openstack:secret@0.0.0.0:5672 +my_ip = 0.0.0.0 periodic_interval = 60 rootwrap_config = /etc/venus/rootwrap.conf api_paste_config = /etc/venus/api-paste.ini -log_dir = /var/log/kolla/venus/ +use_syslog = False debug = True -use_stderr = True auth_strategy = keystone os_region_name = RegionOne -osapi_venus_listen = 100.2.30.243 -osapi_venus_listen_port = 8686 +osapi_venus_listen_port = 10010 osapi_venus_workers = 1 [database] -connection = mysql+pymysql://root:Irpzw6tic9ezyUEh4c0JnT0kK7U1oKqbRPRIfkwW@100.2.28.72:3306/venus?charset=utf8 +connection = mysql+pymysql://root:secret@localhost:3306/venus?charset=utf8 [elasticsearch] -url = http://100.2.28.30:9200 -username = admin -password = DlR7Y4vcPPbwbOCHYO8f8zG9VtwnLrd1t5R1A3B9 +url = http://localhost:9200 diff --git a/setup.cfg b/setup.cfg index 87b398f..0297934 100644 --- a/setup.cfg +++ b/setup.cfg @@ -24,8 +24,6 @@ packages = venus [entry_points] -venus.database.migration_backend = - sqlalchemy = venus.db.sqlalchemy.migration - -wsgi_scripts = - venus-api-wsgi = venus.cmd.api:main \ No newline at end of file +console_scripts = + venus-manage = venus.cmd.manage:main + venus-api = venus.cmd.api:main diff --git a/venus/cmd/api.py b/venus/cmd/api.py index c9763a4..60c6d42 100644 --- a/venus/cmd/api.py +++ b/venus/cmd/api.py @@ -15,7 +15,6 @@ """Starter script for Venus OS API.""" import eventlet -import os import sys from oslo_log import log as logging @@ -36,10 +35,10 @@ def main(): objects.register_all() CONF(sys.argv[1:], project='venus', version=version.version_string()) - logdir = CONF.log_dir - is_exits = os.path.exists(logdir) - if not is_exits: - os.makedirs(logdir) + # logdir = CONF.log_dir + # is_exits = os.path.exists(logdir) + # if not is_exits: + # os.makedirs(logdir) logging.setup(CONF, "venus") utils.monkey_patch() diff --git a/venus/cmd/manage.py b/venus/cmd/manage.py index 91cb3ce..80016a3 100644 --- a/venus/cmd/manage.py +++ b/venus/cmd/manage.py @@ -345,10 +345,10 @@ def main(): try: CONF(sys.argv[1:], project='venus', version=version.version_string()) - logdir = CONF.log_dir - is_exits = os.path.exists(logdir) - if not is_exits: - os.makedirs(logdir) + # logdir = CONF.log_dir + # is_exits = os.path.exists(logdir) + # if not is_exits: + # os.makedirs(logdir) logging.setup(CONF, "venus") except cfg.ConfigDirNotFoundError as details: print(_("Invalid directory: %s") % details) diff --git a/venus/conf/api.py b/venus/conf/api.py index ba8fc38..9693db5 100644 --- a/venus/conf/api.py +++ b/venus/conf/api.py @@ -23,7 +23,7 @@ service_opts = [ default=60, help='Range, in seconds, to randomly delay when starting the' ' periodic task scheduler to reduce stampeding.' - ' (Disable by setting to 0)'), + ' (Disable by settings to 0)'), cfg.StrOpt('osapi_venus_listen', default="0.0.0.0", help='IP address on which OpenStack Venus API listens'), diff --git a/venus/conf/common.py b/venus/conf/common.py index a1e7f24..1b15242 100644 --- a/venus/conf/common.py +++ b/venus/conf/common.py @@ -134,7 +134,8 @@ global_opts = [ default=True, help='If False, closes the client socket connection ' 'explicitly. Setting it to True to maintain backward ' - 'compatibility. Recommended setting is set it to False.'), + 'compatibility. Recommended settings is set it ' + 'to False.'), cfg.BoolOpt('fatal_exception_format_errors', default=False, help='Make exception message format errors fatal.'), diff --git a/venus/db/migration.py b/venus/db/migration.py index c823def..c910357 100644 --- a/venus/db/migration.py +++ b/venus/db/migration.py @@ -17,42 +17,41 @@ import os import threading -from oslo_db import options -from stevedore import driver - -from venus.conf import CONF -from venus.db.sqlalchemy import api as db_api +from oslo_config import cfg +from oslo_db import options as db_options +from oslo_db.sqlalchemy.migration import db_sync as sync +from oslo_db.sqlalchemy import session as db_session INIT_VERSION = 000 _IMPL = None _LOCK = threading.Lock() -options.set_defaults(CONF) +db_options.set_defaults(cfg.CONF) MIGRATE_REPO_PATH = os.path.join( os.path.abspath(os.path.dirname(__file__)), - 'sqlalchemy', - 'migrate_repo', + 'sqlalchemy/migrate_repo', ) -def get_backend(): +def get_engine(): + print(cfg.CONF) global _IMPL if _IMPL is None: with _LOCK: if _IMPL is None: - _IMPL = driver.DriverManager( - "venus.database.migration_backend", - CONF.database.backend).driver - return _IMPL + _IMPL = db_session.EngineFacade( + cfg.CONF.database.connection, + **dict(cfg.CONF.database) + ) + return _IMPL.get_engine() def db_sync(version=None, init_version=INIT_VERSION, engine=None): """Migrate the database to `version` or the most recent version.""" - if engine is None: - engine = db_api.get_engine() - return get_backend().db_sync(engine=engine, - abs_path=MIGRATE_REPO_PATH, - version=version, - init_version=init_version) + engine = get_engine() + return sync(engine=engine, + abs_path=MIGRATE_REPO_PATH, + version=version, + init_version=init_version) diff --git a/zzh/readme.txt b/zzh/readme.txt deleted file mode 100644 index 6d9a422..0000000 --- a/zzh/readme.txt +++ /dev/null @@ -1 +0,0 @@ -My fist commit.