Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
8dfbfe31
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
8dfbfe31
编写于
1月 19, 2009
作者:
G
Guido Günther
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
daemonize qemu processes
上级
5d99a309
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
33 addition
and
13 deletion
+33
-13
ChangeLog
ChangeLog
+7
-0
src/qemu_driver.c
src/qemu_driver.c
+26
-13
未找到文件。
ChangeLog
浏览文件 @
8dfbfe31
Mon Jan 19 22:50:53 CET 2009 Guido Günther <agx@sigxcpu.org>
daemonize qemu processes
* src/qemu_driver.c (qemudStartVMDaemon): virExec qemu/kvm via
VIR_EXEC_DAEMON
(qemudShutdownVMDaemon): use virKillProcess, don't waitpid
Mon Jan 19 21:54:25 CET 2009 Guido Günther <agx@sigxcpu.org>
save domstate as string in status file
...
...
src/qemu_driver.c
浏览文件 @
8dfbfe31
...
...
@@ -941,6 +941,7 @@ static int qemudStartVMDaemon(virConnectPtr conn,
unsigned
int
qemuCmdFlags
;
fd_set
keepfd
;
const
char
*
emulator
;
pid_t
child
;
FD_ZERO
(
&
keepfd
);
...
...
@@ -1039,12 +1040,26 @@ static int qemudStartVMDaemon(virConnectPtr conn,
for
(
i
=
0
;
i
<
ntapfds
;
i
++
)
FD_SET
(
tapfds
[
i
],
&
keepfd
);
ret
=
virExec
(
conn
,
argv
,
progenv
,
&
keepfd
,
&
vm
->
pi
d
,
ret
=
virExec
(
conn
,
argv
,
progenv
,
&
keepfd
,
&
chil
d
,
vm
->
stdin_fd
,
&
vm
->
stdout_fd
,
&
vm
->
stderr_fd
,
VIR_EXEC_NONBLOCK
);
if
(
ret
==
0
)
VIR_EXEC_NONBLOCK
|
VIR_EXEC_DAEMON
);
/* wait for qemu process to to show up */
if
(
ret
==
0
)
{
int
retries
=
100
;
while
(
retries
)
{
if
((
ret
=
virFileReadPid
(
driver
->
stateDir
,
vm
->
def
->
name
,
&
vm
->
pid
))
==
0
)
break
;
usleep
(
100
*
1000
);
retries
--
;
}
if
(
ret
)
qemudLog
(
QEMUD_WARN
,
_
(
"Domain %s didn't show up
\n
"
),
vm
->
def
->
name
);
}
if
(
ret
==
0
)
{
vm
->
state
=
migrateFrom
?
VIR_DOMAIN_PAUSED
:
VIR_DOMAIN_RUNNING
;
else
}
else
vm
->
def
->
id
=
-
1
;
for
(
i
=
0
;
argv
[
i
]
;
i
++
)
...
...
@@ -1121,7 +1136,10 @@ static void qemudShutdownVMDaemon(virConnectPtr conn ATTRIBUTE_UNUSED,
qemudLog
(
QEMUD_INFO
,
_
(
"Shutting down VM '%s'
\n
"
),
vm
->
def
->
name
);
kill
(
vm
->
pid
,
SIGTERM
);
if
(
virKillProcess
(
vm
->
pid
,
0
)
==
0
&&
virKillProcess
(
vm
->
pid
,
SIGTERM
)
<
0
)
qemudLog
(
QEMUD_ERROR
,
_
(
"Failed to send SIGTERM to %s (%d): %s
\n
"
),
vm
->
def
->
name
,
vm
->
pid
,
strerror
(
errno
));
qemudVMData
(
driver
,
vm
,
vm
->
stdout_fd
);
qemudVMData
(
driver
,
vm
,
vm
->
stderr_fd
);
...
...
@@ -1141,15 +1159,10 @@ static void qemudShutdownVMDaemon(virConnectPtr conn ATTRIBUTE_UNUSED,
vm
->
stderr_fd
=
-
1
;
vm
->
monitor
=
-
1
;
if
(
waitpid
(
vm
->
pid
,
NULL
,
WNOHANG
)
!=
vm
->
pid
)
{
kill
(
vm
->
pid
,
SIGKILL
);
if
(
waitpid
(
vm
->
pid
,
NULL
,
0
)
!=
vm
->
pid
)
{
qemudLog
(
QEMUD_WARN
,
"%s"
,
_
(
"Got unexpected pid, damn
\n
"
));
}
}
qemudRemoveDomainStatus
(
conn
,
driver
,
vm
);
/* shut it off for sure */
virKillProcess
(
vm
->
pid
,
SIGKILL
);
qemudRemoveDomainStatus
(
conn
,
driver
,
vm
);
vm
->
pid
=
-
1
;
vm
->
def
->
id
=
-
1
;
vm
->
state
=
VIR_DOMAIN_SHUTOFF
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录