您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“kvm虛擬機vnc和spice如何配置”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“kvm虛擬機vnc和spice如何配置”這篇文章吧。
通過vnc或spice方式訪問虛擬主機上的KVM虛擬機,可以直接通過圖形化界面virt-manager來設置,但此處通過xml配置文件修改。
vnc方式訪問虛擬機不是在kvm虛擬機安裝配置vnc服務器,通過虛擬主機的IP地址與端口進行訪問,kvm虛擬化對vnc的支持相對來說比xen要好很多,在虛擬主機上配置VNC訪問虛擬機,也是為了多提供一種方式訪問虛擬機而已。
(1)修改qemu.conf(也可不修改,默認是127.0.0.1)
#vi /etc/libvirt/qemu.conf
vnc_listen = "0.0.0.0"
重啟libvirt
#systemctl restart libvirtd.service
vnclisten默認綁定127.0.0.1,在配置文件里指定VNC綁定0.0.0.0,就不用在安裝kvm虛擬機時指定vnclisten參數了。當在虛擬主機上有很多個虛擬機的時候,若指定每個虛擬機的端口,將會很亂,所以采用0.0.0.0自動分配端口。
(2)修改目標虛擬機smb3.1的配置文件
#virsh list --all
#virsh edit smb3.1
<graphics type='vnc' port='-1' autoport='yes' listen='0.0.0.0'>
<listen type='address' address='0.0.0.0'/>
</graphics>
#virsh start smb3.1
(3)查看運行虛擬機的vnc端口
查看vnc端口#virsh vncdisplay smb3.1
:0
也可以通過virsh命令動態查看虛擬機的xml配置文件#virsh dumpxml smb3.1
(4)vnc登錄
windows下可以通過vnc viewer或TightVNC或RealVNC等工具登錄。
linux下也可以通過#virt-viewer --connect qemu:///system smb3.1訪問,非本機的linux通過#virt-viewer qemu+ssh://root@192.168.40.125/system smb3.1訪問。
(5)vnc源碼登錄
kde桌面的源碼包kdenetwork中可以找到krdc/vnc中關于vnc的源碼,提取vncview.cpp、vncclientthread.cpp和remoteview.cpp即可運行vnc。
#include "widget.h"
#include "vncview.h"
Widget::Widget(QWidget *parent)
: QWidget(parent, Qt::WindowMinimizeButtonHint | Qt::WindowCloseButtonHint)
{
resize(900+20, 900+20);
VncView *vncView = new VncView(this, QUrl("vnc://:@192.168.40.125:5901"));
vncView->enableScaling(true);
vncView->scaleResize(900, 900);
vncView->show();
vncView->start();
}
Widget::~Widget()
{
}
(1)修改目標虛擬機smb3.1的配置文件
#virsh list --all
#virsh edit smb3.0
[html] view plain copy
<graphics type='spice' autoport='yes' listen='0.0.0.0'>
<listen type='address' address='0.0.0.0'/>
</graphics>
#virsh start smb3.0
(2)查看運行虛擬機的vnc端口
#netstat -tunlp
a
或通過virsh命令動態查看虛擬機的xml配置文件#virsh dumpxml smb3.0
也可以通過命令#spicy -h 127.0.0.1 -p 5900(需安裝spice-gtk-tools軟件包)。
(4)spice源碼登錄
spice-gtk提供了完整的gtk界面。
[html] view plain copy
#include <stdio.h>
#include <stdlib.h>
#include <getopt.h>
#include <gtk/gtk.h>
#include <spice-channel.h>
#include <spice-session.h>
#include <spice-widget.h>
static GtkWidget *main_window;
static SpiceSession *spice_session;
static SpiceDisplay *spice_display;
static char *host;
static char *port;
static void channel_new(SpiceSession *s, SpiceChannel *c, gpointer *data)
{
int id = 0;
g_object_get(c, "channel-id", &id, NULL);
if (SPICE_IS_MAIN_CHANNEL(c)) {
fprintf(stdout, "new main channel\n");
return;
}
if (SPICE_IS_DISPLAY_CHANNEL(c)) {
fprintf(stdout, "new display channel (#%d), creating window\n", id);
spice_display = spice_display_new(s, id);
gtk_container_add(GTK_CONTAINER(main_window), GTK_WIDGET(spice_display));
gtk_widget_show_all(main_window);
return;
}
}
static void usage()
{
fprintf(stdout, "spice-client: A spice client\n"
"Usage: spice-client [options]...\n"
" -h, --host\n"
" Set address of spice server\n"
" -p, --port\n"
" Set port of spice server\n"
" -e, --help\n"
" Print help and exit\n"
);
}
static void parse_cmd(int argc, char *argv[])
{
int c, e = 0;
if (argc == 1) {
usage();
exit(1);
}
const struct option long_options[] = {
{ "help", 0, 0, 'e' },
{ "host", 0, 0, 'h' },
{ "port", 0, 0, 'p' },
{ 0, 0, 0, 0 },
};
while ((c = getopt_long(argc, argv, "eh:p:",
long_options, NULL)) != EOF) {
switch (c) {
case 'e':
goto failed;
case 'h':
host = optarg;
break;
case 'p':
port = optarg;
break;
default:
e++;
break;
}
}
if (e || argc > optind) {
goto failed;
}
if (host == NULL || port == NULL) {
fprintf(stderr, "No host or port found\n");
goto failed;
}
return ;
failed:
usage();
exit(1);
}
int main(int argc, char *argv[])
{
parse_cmd(argc, argv);
gtk_init(&argc, &argv);
main_window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
spice_session = spice_session_new();
g_object_set(spice_session, "host", host, NULL);
g_object_set(spice_session, "port", port, NULL);
g_signal_connect(spice_session, "channel-new",
G_CALLBACK(channel_new), NULL);
if (!spice_session_connect(spice_session)) {
fprintf(stderr, "spice_session_connect failed\n");
exit(1);
}
gtk_main();
return 0;
}
gcc -o spice-client client.c `pkg-config --cflags --libs spice-client-gtk-2.0`
./spice-client -h 127.0.0.1 -p 5900
以上是“kvm虛擬機vnc和spice如何配置”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。