|
Criando um serviço Solaris10
Os passos gerais necessários são:
o Determine o processo para iniciar e parar o seu serviço.
o Criar um nome para o serviço, bem como da categoria este serviço cai em.
o Determinar se o seu serviço é executado várias instâncias.
o Identificar qualquer dependência das relações entre este serviço e qualquer outro serviço.
o Se um script é necessário para iniciar e parar o processo, criar o script e colocá-lo em um diretório local, tais como / usr / local / svc / método
o Criar um serviço de arquivo manifesto para o seu serviço. Este arquivo descreve o serviço e qualquer dependência relacionamentos. Serviço manifestos são puxados para o repositório usando svccfg comando ou no momento de arranque.
o Incorporar os scripts em SMF usando o utilitário svccfg.
O seguinte mostra um exemplo.
Código:
# vi /usr/local/svc/method/newservice
#!/sbin/sh
#
# Copyright (c) 1995, 1997-1999 by Sun Microsystems, Inc.
# All rights reserved.
#
#ident "@(#)newservice 1.14 06/11/17 SMI"
case "$1" in
'start')
/usr/bin/newservice &
;;
'stop')
/usr/bin/pkill -x -u 0 newservice
;;
*0
echo "Usage: $0 { start | stop }"
;;
esac
exit 0
# chmod 544 /usr/local/svc/method/newservice
# cd /var/svc/manifest/site
# vi newservice.xml
<?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
<!--
Copyright 2004 Sun Microsystems, Inc. All rights reserved.
Use is subject to license terms.
pragma ident "@(#)newservice.xml 1.2 04/08/09 SMI"
-->
<service_bundle type='manifest' name='OPTnew:newservice'>
<service
name='site/newservice'
type='service'
version='1'>
<single_instance/>
<dependency
name='usr'
type='service'
grouping='require_all'
restart_on='none'>
<service_fmri value='svc:/system/filesystem/local'/>
</dependency>
<dependency
name='newservice'
grouping='require_all'
restart_on='none'>
<service_fmri value='svc:/milestone/multi-user'/>
</dependency>
<exec_method
type='method'
name='start'
exec='/lib/svc/method/newservice start'
timeout_seconds='30' />
<exec_method
type='method'
name='stop'
exec='/lib/svc/method/newservice stop'
timeout_seconds='30' />
<property_group name='startd' type='framework'>
<propval name='duration' type='astring' value='transient' />
</property_group>
<instance name='default' enabled='true' />
<stability value='Unstable' />
<template>
<common_name>
<loctext xml:lang='C'>
New Service
</loctext>
</common_name>
</template>
</service>
</service_bundle>
A seguir descreve as entradas no arquivo:
o Standard Header.
Código:
<?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM
"/usr/share/lib/xml/dtd/service_bundle.dtd.1">
o Comentar secção.
Código:
<!--
Copyright 2004 Sun Microsystems, Inc. All rights reserved.
Use is subject to license terms.
pragma ident "@(#)newservice.xml 1.2 04/08/09 SMI"
-->
o O nome do serviço. o tipo (manifesto), indica um simples serviço em vez de um marco, o pacote que fornece o serviço, bem como o nome do serviço.
Código:
<service_bundle type='manifest' name='OPTnew:newservice'>
o Categoria de serviço, tipo, nome e versão.
Código:
<service
name='site/newservice'
type='service'
version='1'
o Se várias instâncias do serviço será executado.
Código:
<single_instance/>
o o modelo de serviço para uso. A entrada indica que o serviço será iniciado por svc.startd. transiente serviços foram iniciados uma vez e não reiniciado.
Código:
<property_group name='startd' type='framework'>
<propval name='duration' type='astring' value='transient' />
</property_group>
o Como o serviço é iniciado e parado.
Código:
<exec_method
type='method'
name='start'
exec='/lib/svc/method/newservice start'
timeout_seconds='30' />
<exec_method
type='method'
name='stop'
exec='/lib/svc/method/newservice stop'
timeout_seconds='30' />
o Defina quaisquer dependências para este serviço. A primeira afirma que a entrada newservice exige o sistema de arquivos / serviço local.
Código:
<dependency
name='usr'
type='service'
grouping='require_all'
restart_on='none'>
<service_fmri value='svc:/system/filesystem/local'/>
</dependency>
o A segunda entrada torna a certeza de que o serviço é associado com o multi-usuário marco e que o multi-usuário marco exige este serviço.
Código:
<dependency
name='newservice'
grouping='require_all'
restart_on='none'>
<service_fmri value='svc:/milestone/multi-user'/>
</dependency>
o Criando o exemplo.
Código:
<instance name='default' enabled='true' />
<stability value='Unstable' />
o Criando informações para descrever o serviço.
Código:
<template>
<common_name>
<loctext xml:lang='C'>
New Service
</loctext>
</common_name>
</template>
O novo serviço (newservice) agora tem de ser importado para SMF.
Isto é feito por correr o utilitário svccfg:
Código:
# svccfg import /var/svc/manifest/site/newservice.xml
Depois que o serviço foi importado para o SMF que deve ser visível usando o comando SVCS.
Código:
# svcs newservice
STATE STIME FMRI
online 8:57:35 svc:/site/newservice:default
#
Deverá também ser possível manipular o serviço utilizando svcadm.
Código:
# svcadm -v disable site/newservice
site/newservice disabled.
# svcs newservice
STATE STIME FMRI
disabled 9:07:15 svc:/site/newservice:default
# svcadm -v enable site/newservice
site/newservice enabled.
# svcs newservice
STATE STIME FMRI
online 9:17:01 svc:/site/newservice:default
#
Finalmente, você pode observar que o marco multiusuário requer a newservice, a fim de completar as suas necessidades.
Código:
# svcs -d milestone/multi-user:default
STATE STIME FMRI
disabled 8:43:16 svc:/platform/sun4u/sf880drd:default
online 8:43:16 svc:/milestone/name-services:default
online 8:43:33 svc:/system/rmtmpfiles:default
online 8:43:42 svc:/network/rpc/bind:default
online 8:43:46 svc:/milestone/single-user:default
online 8:43:46 svc:/system/utmp:default
online 8:43:47 svc:/system/system-log:default
online 8:43:49 svc:/system/filesystem/local:default
online 8:44:01 svc:/system/mdmonitor:default
online 9:17:01 svc:/site/newservice:default
#
Última edição por maçarico; em 11/16/2006 08:12.. Motivo: a correção incompleta tag XML para o serviço. o fechamento '>' não estava presente
|