openstack-config --set命令
时间: 2023-10-06 17:08:03 浏览: 247
`openstack-config --set` 命令用于设置 OpenStack 配置文件中的选项值。具体使用方法如下:
```bash
openstack-config --set /path/to/config-file section option value
```
其中,`/path/to/config-file` 是配置文件的路径;`section` 是配置文件中的节名;`option` 是需要设置的选项名;`value` 是需要设置的选项值。
例如,如果需要在 `nova.conf` 配置文件中将 `verbose` 选项的值设置为 `True`,可以使用以下命令:
```bash
openstack-config --set /etc/nova/nova.conf DEFAULT verbose True
```
这样就会将 `nova.conf` 文件中 `[DEFAULT]` 节下的 `verbose` 选项的值设置为 `True`。
相关问题
openeuler安装openstack
以下是在openeuler上安装OpenStack的步骤:
1. 确保你的openeuler系统已经安装了必要的软件包和依赖项。可以使用以下命令安装:
```shell
sudo dnf install -y python3-devel libffi-devel gcc openssl-devel
```
2. 添加OpenStack Train软件源。可以使用以下命令添加:
```shell
sudo dnf install -y centos-release-openstack-train
```
3. 安装OpenStack客户端和服务组件。可以使用以下命令安装:
```shell
sudo dnf install -y python3-openstackclient openstack-selinux openstack-utils
```
4. 配置数据库。可以使用以下命令安装MariaDB数据库:
```shell
sudo dnf install -y mariadb mariadb-server python3-PyMySQL
```
然后启动MariaDB服务并设置开机自启:
```shell
sudo systemctl enable mariadb.service
sudo systemctl start mariadb.service
```
接下来,使用以下命令来配置MariaDB数据库:
```shell
sudo mysql_secure_installation
```
5. 配置消息队列。可以使用以下命令安装RabbitMQ消息队列:
```shell
sudo dnf install -y rabbitmq-server
```
然后启动RabbitMQ服务并设置开机自启:
```shell
sudo systemctl enable rabbitmq-server.service
sudo systemctl start rabbitmq-server.service
```
6. 配置身份认证服务。可以使用以下命令安装Keystone身份认证服务:
```shell
sudo dnf install -y openstack-keystone httpd mod_wsgi
```
然后启动httpd服务并设置开机自启:
```shell
sudo systemctl enable httpd.service
sudo systemctl start httpd.service
```
7. 配置计算服务。可以使用以下命令安装Nova计算服务:
```shell
sudo dnf install -y openstack-nova-api openstack-nova-conductor \
openstack-nova-console openstack-nova-novncproxy \
openstack-nova-scheduler python3-novaclient
```
8. 配置网络服务。可以使用以下命令安装Neutron网络服务:
```shell
sudo dnf install -y openstack-neutron openstack-neutron-ml2 \
openstack-neutron-linuxbridge ebtables ipset
```
9. 配置镜像服务。可以使用以下命令安装Glance镜像服务:
```shell
sudo dnf install -y openstack-glance
```
10. 配置块存储服务。可以使用以下命令安装Cinder块存储服务:
```shell
sudo dnf install -y openstack-cinder targetcli python-keystone
```
11. 配置对象存储服务。可以使用以下命令安装Swift对象存储服务:
```shell
sudo dnf install -y openstack-swift-proxy python3-swiftclient \
python3-keystoneclient python3-keystonemiddleware \
python3-eventlet xfsprogs rsync
```
12. 配置Dashboard服务。可以使用以下命令安装Horizon Dashboard服务:
```shell
sudo dnf install -y openstack-dashboard
```
13. 配置OpenStack服务。可以使用以下命令配置OpenStack服务:
```shell
sudo openstack-config --set /etc/nova/nova.conf database connection mysql+pymysql://nova:password@controller/nova
sudo openstack-config --set /etc/nova/nova.conf DEFAULT transport_url rabbit://openstack:password@controller
sudo openstack-config --set /etc/nova/nova.conf api auth_strategy keystone
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken www_authenticate_uri http://controller:5000
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken auth_type password
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken project_domain_name Default
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken user_domain_name Default
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken project_name service
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken username nova
sudo openstack-config --set /etc/nova/nova.conf keystone_authtoken password password
sudo openstack-config --set /etc/nova/nova.conf DEFAULT my_ip 10.0.0.11
sudo openstack-config --set /etc/nova/nova.conf DEFAULT use_neutron True
sudo openstack-config --set /etc/nova/nova.conf DEFAULT firewall_driver nova.virt.firewall.NoopFirewallDriver
sudo openstack-config --set /etc/nova/nova.conf vnc enabled true
sudo openstack-config --set /etc/nova/nova.conf vnc server_listen 0.0.0.0
sudo openstack-config --set /etc/nova/nova.conf vnc server_proxyclient_address \$my_ip
sudo openstack-config --set /etc/nova/nova.conf vnc novncproxy_base_url http://controller:6080/vnc_auto.html
sudo openstack-config --set /etc/nova/nova.conf glance api_servers http://controller:9292
sudo openstack-config --set /etc/nova/nova.conf oslo_concurrency lock_path /var/lib/nova/tmp
sudo openstack-config --set /etc/neutron/neutron.conf database connection mysql+pymysql://neutron:password@controller/neutron
sudo openstack-config --set /etc/neutron/neutron.conf DEFAULT transport_url rabbit://openstack:password@controller
sudo openstack-config --set /etc/neutron/neutron.conf DEFAULT auth_strategy keystone
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken www_authenticate_uri http://controller:5000
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken auth_type password
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_domain_name Default
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken user_domain_name Default
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken project_name service
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken username neutron
sudo openstack-config --set /etc/neutron/neutron.conf keystone_authtoken password password
sudo openstack-config --set /etc/neutron/neutron.conf oslo_concurrency lock_path /var/lib/neutron/tmp
sudo openstack-config --set /etc/glance/glance-api.conf database connection mysql+pymysql://glance:password@controller/glance
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken www_authenticate_uri http://controller:5000
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken auth_type password
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken project_domain_name Default
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken user_domain_name Default
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken project_name service
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken username glance
sudo openstack-config --set /etc/glance/glance-api.conf keystone_authtoken password password
sudo openstack-config --set /etc/glance/glance-api.conf paste_deploy flavor keystone
sudo openstack-config --set /etc/glance/glance-api.conf glance_store stores file,http
sudo openstack-config --set /etc/glance/glance-api.conf glance_store default_store file
sudo openstack-config --set /etc/glance/glance-api.conf glance_store filesystem_store_datadir /var/lib/glance/images/
sudo openstack-config --set /etc/glance/glance-registry.conf database connection mysql+pymysql://glance:password@controller/glance
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken www_authenticate_uri http://controller:5000
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken auth_type password
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken project_domain_name Default
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken user_domain_name Default
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken project_name service
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken username glance
sudo openstack-config --set /etc/glance/glance-registry.conf keystone_authtoken password password
sudo openstack-config --set /etc/glance/glance-registry.conf paste_deploy flavor keystone
sudo openstack-config --set /etc/cinder/cinder.conf database connection mysql+pymysql://cinder:password@controller/cinder
sudo openstack-config --set /etc/cinder/cinder.conf DEFAULT transport_url rabbit://openstack:password@controller
sudo openstack-config --set /etc/cinder/cinder.conf DEFAULT auth_strategy keystone
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken www_authenticate_uri http://controller:5000
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken auth_type password
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken project_domain_name Default
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken user_domain_name Default
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken project_name service
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken username cinder
sudo openstack-config --set /etc/cinder/cinder.conf keystone_authtoken password password
sudo openstack-config --set /etc/cinder/cinder.conf oslo_concurrency lock_path /var/lib/cinder/tmp
sudo openstack-config --set /etc/swift/proxy-server.conf DEFAULT bind_port 8080
sudo openstack-config --set /etc/swift/proxy-server.conf DEFAULT user swift
sudo openstack-config --set /etc/swift/proxy-server.conf DEFAULT swift_dir /etc/swift
sudo openstack-config --set /etc/swift/proxy-server.conf pipeline:main pipeline "catch_errors healthcheck cache authtoken keystoneauth proxy-server"
sudo openstack-config --set /etc/swift/proxy-server.conf filter:keystoneauth use "egg:swift#keystoneauth"
sudo openstack-config --set /etc/swift/proxy-server.conf filter:keystoneauth operator_roles admin,user
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken paste.filter_factory keystonemiddleware.auth_token:filter_factory
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken auth_uri http://controller:5000
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken auth_url http://controller:5000
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken memcached_servers controller:11211
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken auth_type password
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken project_domain_name Default
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken user_domain_name Default
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken project_name service
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken username swift
sudo openstack-config --set /etc/swift/proxy-server.conf filter:authtoken password password
sudo openstack-config --set /etc/swift/proxy-server.conf filter:cache use "egg:swift#memcache"
sudo openstack-config --set /etc/swift/proxy-server.conf filter:cache memcache_servers controller:11211
sudo openstack-config --set /etc/swift/proxy-server.conf filter:
优化下面代码:def watcher_maintenance_config(target_status): """The Watcher supports set system maintenance mode. Stop audits execution while set system maintenance mode, resume audits execution while unset system maintenance mode. """ # Check the node is master host first then check exists # openstack-watcher-api service. is_master = is_master_host() is_active = is_watcher_api_active() if not (is_master and is_active): logger("Ignore %s system maintenance mode on the node which is not " "master or watcher api is not started on." % target_status) return False return execute(target_status)
下面是优化后的代码:
```python
def watcher_maintenance_config(target_status):
"""The Watcher supports set system maintenance mode.
Stop audits execution while set system maintenance mode, resume audits
execution while unset system maintenance mode.
"""
# Check the node is master host first then check exists
# openstack-watcher-api service.
if not (is_master_host() and is_watcher_api_active()):
logger("Ignore %s system maintenance mode on the node which is not "
"master or watcher api is not started on." % target_status)
return False
return execute(target_status)
```
在优化后的代码中,我将 `is_master_host()` 和 `is_watcher_api_active()` 的结果直接用于判断条件,避免了多次函数调用。这样可以提高代码的效率。
阅读全文