Add novnc console support

This change adds in support for the novnc console type in Nova.

* The change adds in a few new variables to the defaults which allow
  for the novnc console to be configued.
* A port entry was added to haproxy to support the console type.
* noVNC is being installed from source in the nova_console container.
  The git repo has been added to the openstack_other.yml repo-package file
  which allows for the repo to be cloned into the repo containers and then
  distributed out where needed from within the environment.

Closes-Bug: 1428833

Change-Id: I221557aad77bf266b4e2fae23007ffa210aa1f75
Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
This commit is contained in:
Kevin Carter 2015-09-25 20:50:42 -05:00 committed by Jesse Pretorius
parent b380726cbf
commit 0681e25a52
12 changed files with 187 additions and 20 deletions

View File

@ -41,3 +41,8 @@ openstackclient_git_dest: "/opt/openstackclient_{{ openstackclient_git_install_b
djangoopenstackauth_git_repo: https://github.com/openstack/django_openstack_auth djangoopenstackauth_git_repo: https://github.com/openstack/django_openstack_auth
djangoopenstackauth_git_install_branch: 829cbee14e200fd127ec4f0e0f4d743102d8e9d1 djangoopenstackauth_git_install_branch: 829cbee14e200fd127ec4f0e0f4d743102d8e9d1
djangoopenstackauth_git_dest: "/opt/djangoopenstackauth_{{ djangoopenstackauth_git_install_branch | replace('/', '_') }}" djangoopenstackauth_git_dest: "/opt/djangoopenstackauth_{{ djangoopenstackauth_git_install_branch | replace('/', '_') }}"
# NOVNC from source
novncproxy_git_repo: https://github.com/kanaka/novnc
novncproxy_git_install_branch: a0e7ab43dca0ce11a713694ee4cf530bd3b17c5a
novncproxy_git_dest: "/opt/novnc_{{ novncproxy_git_install_branch | replace('/', '_') }}"

View File

@ -36,6 +36,7 @@ rsyslog_server_storage_directory: /var/log/log-storage
## OpenStack source options ## OpenStack source options
# URL for the frozen internal openstack repo. # URL for the frozen internal openstack repo.
openstack_repo_url: "http://{{ internal_lb_vip_address }}:{{ repo_server_port }}" openstack_repo_url: "http://{{ internal_lb_vip_address }}:{{ repo_server_port }}"
openstack_repo_git_url: "http://{{ internal_lb_vip_address }}:{{ repo_server_port }}/openstackgit"
## LXC options ## LXC options

View File

@ -111,13 +111,20 @@
tags: tags:
- nova-logs - nova-logs
roles: roles:
- { role: "os_nova", tags: [ "os-nova" ] } - role: "os_nova"
nova_novncproxy_git_repo: "{{ openstack_repo_git_url }}/novnc"
nova_novncproxy_git_install_branch: "{{ novncproxy_git_install_branch }}"
nova_galera_address: "{{ internal_lb_vip_address }}"
tags:
- "os-nova"
- role: "ceph_client" - role: "ceph_client"
openstack_service_system_user: "{{ nova_system_user_name }}" openstack_service_system_user: "{{ nova_system_user_name }}"
tags: tags:
- "nova-ceph-client" - "nova-ceph-client"
- "ceph-client" - "ceph-client"
- { role: "openstack_openrc", tags: [ "openstack-openrc" ] } - role: "openstack_openrc"
tags:
- "openstack-openrc"
- role: "rsyslog_client" - role: "rsyslog_client"
rsyslog_client_log_rotate_file: nova_log_rotate rsyslog_client_log_rotate_file: nova_log_rotate
rsyslog_client_log_dir: "/var/log/nova" rsyslog_client_log_dir: "/var/log/nova"
@ -130,8 +137,9 @@
- "system-crontab-coordination" - "system-crontab-coordination"
vars: vars:
galera_address: "{{ internal_lb_vip_address }}" galera_address: "{{ internal_lb_vip_address }}"
nova_galera_address: "{{ internal_lb_vip_address }}"
ansible_hostname: "{{ container_name }}" ansible_hostname: "{{ container_name }}"
ansible_ssh_host: "{{ container_address }}" ansible_ssh_host: "{{ container_address }}"
is_metal: "{{ properties.is_metal|default(false) }}" is_metal: "{{ properties.is_metal|default(false) }}"
glance_host: "{{ internal_lb_vip_address }}" glance_host: "{{ internal_lb_vip_address }}"
vars_files:
- defaults/repo_packages/openstack_other.yml

View File

@ -28,6 +28,7 @@
create-report \ create-report \
--report-file {{ repo_service_home_folder }}/repo/reports/release-{{ openstack_release }}-report.json \ --report-file {{ repo_service_home_folder }}/repo/reports/release-{{ openstack_release }}-report.json \
--git-install-repos {{ item['remote_packages'] }} \ --git-install-repos {{ item['remote_packages'] }} \
--git-repo-path "{{ repo_service_home_folder }}/repo/openstackgit" \
--packages {{ item['packages'] }} --packages {{ item['packages'] }}
with_py_pkgs: ../ with_py_pkgs: ../
sudo: yes sudo: yes
@ -49,6 +50,7 @@
--build-output "{{ repo_build_output }}" \ --build-output "{{ repo_build_output }}" \
--build-dir "{{ repo_build_dir }}" \ --build-dir "{{ repo_build_dir }}" \
--build-requirements \ --build-requirements \
--git-repo-path "{{ repo_service_home_folder }}/repo/openstackgit" \
--force-clean --force-clean
sudo: yes sudo: yes
sudo_user: "{{ repo_service_user_name }}" sudo_user: "{{ repo_service_user_name }}"
@ -68,6 +70,7 @@
--build-dir "{{ repo_build_dir }}" \ --build-dir "{{ repo_build_dir }}" \
--build-branches \ --build-branches \
--build-releases \ --build-releases \
--git-repo-path "{{ repo_service_home_folder }}/repo/openstackgit" \
--force-clean --force-clean
sudo: yes sudo: yes
sudo_user: "{{ repo_service_user_name }}" sudo_user: "{{ repo_service_user_name }}"
@ -84,6 +87,17 @@
sudo_user: "{{ repo_service_user_name }}" sudo_user: "{{ repo_service_user_name }}"
tags: tags:
- repo-html-indexes - repo-html-indexes
- name: Store all git source
shell: |
yaprt --quiet \
store-repos \
--report-file {{ repo_service_home_folder }}/repo/reports/release-{{ openstack_release }}-report.json \
--git-repo-path "{{ repo_service_home_folder }}/repo/openstackgit"
sudo: yes
sudo_user: "{{ repo_service_user_name }}"
tags:
- repo-store-git-sources
vars: vars:
repo_build_dir: "/tmp/openstack-builder" repo_build_dir: "/tmp/openstack-builder"
repo_build_output: "/tmp/openstack-wheel-output" repo_build_output: "/tmp/openstack-wheel-output"

View File

@ -166,6 +166,19 @@ nova_spice_console_keymap: en-us
nova_spice_console_agent_enabled: True nova_spice_console_agent_enabled: True
nova_spice_program_name: nova-spicehtml5proxy nova_spice_program_name: nova-spicehtml5proxy
## Nova novnc
nova_novncproxy_proto: http
nova_novncproxy_port: 6080
nova_novncproxy_base_uri: "{{ nova_novncproxy_proto }}://{{ external_lb_vip_address }}:{{ nova_novncproxy_port }}"
nova_novncproxy_base_url: "{{ nova_novncproxy_base_uri }}/vnc_auto.html"
nova_novncproxy_vncserver_proxyclient_address: "{{ ansible_ssh_host }}"
nova_novncproxy_vncserver_listen: "{{ ansible_ssh_host }}"
nova_novncproxy_agent_enabled: True
nova_novncproxy_program_name: nova-novncproxy
nova_novncproxy_git_repo: https://github.com/kanaka/novnc
nova_novncproxy_git_install_branch: master
nova_novncproxy_vnc_keymap: en-us
## Nova metadata ## Nova metadata
nova_metadata_proxy_enabled: True nova_metadata_proxy_enabled: True
nova_metadata_port: 8775 nova_metadata_port: 8775
@ -198,7 +211,7 @@ nova_console_agent_enabled: True
nova_consoleauth_program_name: nova-consoleauth nova_consoleauth_program_name: nova-consoleauth
nova_console_agent_enabled: True nova_console_agent_enabled: True
nova_console_keymap: en-us nova_console_keymap: en-us
# Set the console type. Presently the only option is ["spice"]. # Set the console type. Presently the only options are ["spice", "novnc"].
nova_console_type: spice nova_console_type: spice
## Nova global config ## Nova global config
@ -301,6 +314,7 @@ nova_service_names:
- "{{ nova_compute_program_name }}" - "{{ nova_compute_program_name }}"
- "{{ nova_spice_program_name }}" - "{{ nova_spice_program_name }}"
- "{{ nova_consoleauth_program_name }}" - "{{ nova_consoleauth_program_name }}"
- "{{ nova_novncproxy_program_name }}"
# Common apt packages # Common apt packages
nova_apt_packages: nova_apt_packages:
@ -312,6 +326,17 @@ nova_apt_packages:
nova_spice_apt_packages: nova_spice_apt_packages:
- spice-html5 - spice-html5
nova_novnc_apt_packages:
- libjs-jquery
- libjs-sphinxdoc
- libjs-underscore
- libjs-swfobject
- librabbitmq1
- libyaml-0-2
nova_novnc_pip_packages:
- websockify
nova_compute_kvm_apt_packages: nova_compute_kvm_apt_packages:
- bridge-utils - bridge-utils
- genisoimage - genisoimage

View File

@ -15,12 +15,7 @@
- include: nova_pre_install.yml - include: nova_pre_install.yml
- include: nova_install.yml - include: nova_install.yml
- include: nova_console_install.yml
- include: nova_spice_console_install.yml
when: >
inventory_hostname in groups['nova_console'] and
nova_console_type == "spice"
- include: nova_post_install.yml - include: nova_post_install.yml
- include: nova_upstart_init.yml - include: nova_upstart_init.yml

View File

@ -0,0 +1,28 @@
---
# Copyright 2015, Rackspace US, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# 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.
- include: nova_console_spice_install.yml
when:
- inventory_hostname in groups['nova_console']
- nova_console_type == "spice"
tags:
- nova-spice-console
- include: nova_console_novnc_install.yml
when:
- inventory_hostname in groups['nova_console']
- nova_console_type == "novnc"
tags:
- nova-novnc-console

View File

@ -0,0 +1,66 @@
---
# Copyright 2014, Rackspace US, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# 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.
- name: Get package from git
git:
repo: "{{ nova_novncproxy_git_repo }}"
dest: "/usr/share/novnc"
clone: "yes"
update: "yes"
version: "{{ nova_novncproxy_git_install_branch }}"
register: git_clone
until: git_clone|success
retries: 5
delay: 2
tags:
- nova-novnc-git
- name: Update apt sources
apt:
update_cache: yes
cache_valid_time: 600
register: apt_update
until: apt_update|success
retries: 5
delay: 2
tags:
- nova-apt-packages
- nova-novnc-apt-packages
- name: Install apt packages
apt:
pkg: "{{ item }}"
state: latest
register: install_packages
until: install_packages|success
retries: 5
delay: 2
with_items: nova_novnc_apt_packages
tags:
- nova-apt-packages
- nova-novnc-apt-packages
- name: Install pip packages
pip:
name: "{{ item }}"
state: present
register: install_packages
until: install_packages|success
retries: 5
delay: 2
with_items:
- "{{ nova_novnc_pip_packages }}"
tags:
- nova-novnc-pip-packages

View File

@ -37,4 +37,3 @@
tags: tags:
- nova-apt-packages - nova-apt-packages
- nova-spice-apt-packages - nova-spice-apt-packages

View File

@ -97,9 +97,21 @@
system_user: "{{ nova_system_user_name }}" system_user: "{{ nova_system_user_name }}"
system_group: "{{ nova_system_group_name }}" system_group: "{{ nova_system_group_name }}"
service_home: "{{ nova_system_home_folder }}" service_home: "{{ nova_system_home_folder }}"
when: > when:
inventory_hostname in groups ['nova_console'] and - inventory_hostname in groups ['nova_console']
nova_console_type == "spice" - nova_console_type == "spice"
# Upstart init script for novnc console.
- include: nova_upstart_common_init.yml
vars:
program_name: "{{ nova_novncproxy_program_name }}"
service_name: "{{ nova_service_name }}"
system_user: "{{ nova_system_user_name }}"
system_group: "{{ nova_system_group_name }}"
service_home: "{{ nova_system_home_folder }}"
when:
- inventory_hostname in groups ['nova_console']
- nova_console_type == "novnc"
- include: nova_upstart_common_init.yml - include: nova_upstart_common_init.yml
vars: vars:

View File

@ -92,9 +92,6 @@ default_floating_pool = public
security_group_api = neutron security_group_api = neutron
network_api_class = nova.network.neutronv2.api.API network_api_class = nova.network.neutronv2.api.API
# VNC disabled, see spice section
vnc_enabled = False
# Authentication # Authentication
auth_strategy = keystone auth_strategy = keystone
@ -131,7 +128,7 @@ catalog_info = volumev2:cinderv2:internalURL
cross_az_attach = {{ nova_cross_az_attach }} cross_az_attach = {{ nova_cross_az_attach }}
{% if nova_spice_html5proxy_base_url is defined and nova_console_type == "spice" %} {% if nova_console_type == 'spice' %}
[spice] [spice]
agent_enabled = {{ nova_console_agent_enabled }} agent_enabled = {{ nova_console_agent_enabled }}
enabled = {{ nova_console_agent_enabled }} enabled = {{ nova_console_agent_enabled }}
@ -140,8 +137,16 @@ keymap = {{ nova_console_keymap }}
html5proxy_base_url = {{ nova_spice_html5proxy_base_url }} html5proxy_base_url = {{ nova_spice_html5proxy_base_url }}
server_listen = {{ ansible_ssh_host }} server_listen = {{ ansible_ssh_host }}
server_proxyclient_address = {{ ansible_ssh_host }} server_proxyclient_address = {{ ansible_ssh_host }}
{% endif %}
{% elif nova_console_type == 'novnc' %}
[vnc]
enabled = {{ nova_novncproxy_agent_enabled }}
keymap = {{ nova_novncproxy_vnc_keymap }}
novncproxy_base_url = {{ nova_novncproxy_base_url }}
vncserver_listen = {{ nova_novncproxy_vncserver_listen }}
vncserver_proxyclient_address = {{ nova_novncproxy_vncserver_proxyclient_address }}
{% endif %}
# Glance # Glance
[glance] [glance]

View File

@ -128,6 +128,15 @@ haproxy_service_configs:
haproxy_timeout_client: 60m haproxy_timeout_client: 60m
haproxy_timeout_server: 60m haproxy_timeout_server: 60m
haproxy_balance_alg: source haproxy_balance_alg: source
- service:
haproxy_service_name: nova_console_novnc
haproxy_backend_nodes: "{{ groups['nova_console'] }}"
haproxy_ssl: "{% if haproxy_ssl | bool and nova_novncproxy_proto == 'https' %}true{% else %}false{% endif %}"
haproxy_port: 6080
haproxy_balance_type: tcp
haproxy_timeout_client: 60m
haproxy_timeout_server: 60m
haproxy_balance_alg: source
- service: - service:
haproxy_service_name: cinder_api haproxy_service_name: cinder_api
haproxy_backend_nodes: "{{ groups['cinder_api'] }}" haproxy_backend_nodes: "{{ groups['cinder_api'] }}"