Rechercher : dans
Par :

Lancer un script au démarrage

Dernière réponse le 6 aoû 2009 à 13:52:00 Zempachi, le 27 jan 2006 à 19:39:09 
 Signaler ce message aux modérateurs

Salut,
beh tout est dit dans le titre.
En fait je veux lancer deux services avec deux scripts.
J'ai regardé sur le web la maniere de lancer un script au démarrage et j'avoues que ca m'a refroidi.
Donc, en fait je cherche plutot une facon "vite fait" de faire ou une astuce.
Il faut preciser que ces scripts doivent etre lancés avec les droits du root ce qui fait que l'astuce du fichier .bashrc ne fonctionne pas.

Voila merci d'avance.

intermittent de la poésie

Meilleures réponses pour « Lancer un script au démarrage » dans :
Exécuter un script shell VoirExécution d'un script Pour pouvoir exécuter un script ou un programme en ligne de commande il y a plusieurs possibilités : 1. Le chemin absolu 2. Le chemin relatif 3. Modifier la variable PATH Note: Le Sha-Bang Premièrement,...
Lancer un programme au démarrage du PC VoirLe problème Les solutions 1- Sans toucher au registre 2- En modifiant le registre Désactiver son lancement Le problème Certains programmes tels que Mozilla Firefox, Internet explorer ou encore les programmes de messagerie électronique ne...
Désactiver l'exécution de certains programmes au démarrage VoirDésactiver l'exécution de certains programmes au démarrage - Windows 98/Me/2000/XP/Vista Avec msconfig Avec WinPatrol Avec Startuplite Avec CCleaner Remarques Lorsque vous installez des logiciels, certains s'exécutent à chaque...

1

lami20j, le 27 jan 2006 à 19:42:41

Salut,

tu as essayé avec/etc/rc.local (sous fedora c'est le lien pour /etc/rc.d/rc.local )

rc.local c'est le dernier script éxecuté par init.

Répondre à lami20j

2

Zempachi, le 27 jan 2006 à 19:53:16

J'ai pas ce fichier... je suis sous ubuntu.
beh apres un petite rechche sur CCM je crois que je vais passer par l'edition d'un script sous "/etc/init.d/rcX.d/"...

intermittent de la poésie

Répondre à Zempachi

3

lami20j, le 27 jan 2006 à 19:55:54

Re,

Je crois que tu dois créer le fichier rc.local

Voilà ce que j'ai trouvé sur http://loli.fsa.ulaval.ca/mediawiki/index.php/Ubuntu

R: Ubuntu cherche à synchroniser l'heure de votre appareil à chaque démarrage avec un serveur de temps (heure) ou ntp. Le blocage survient lorsque votre système cherche à se brancher alors que votre connexion Internet n'est pas encore activée... Une façon élégante de régler le problème est d'enlever le lien qui lance le protocole ntp et de l'appeler à la toute fin de l'amorce de l'ordi dans un fichier rc.local que nous allons créer.

1. déterminez le niveau par défaut (runlevel)

  cat /etc/inittab | grep initdefault
  la réponse sera sans doute 2

2. créez le fichier rc.local

  sudo touch /etc/init.d/rc.local

3. éditez ses droits

  chmod 774 /etc/init.d/rc.local

4. permettre l'exécution du fichier rc.local en dernier

  sudo ln -s /etc/init.d/rc.local /etc/rc2.d/S99local
  le 99 assure que le fichier sera le dernier processus exécuté lors du démarrage

5. éditez le fichier rc.local pour y mettre les commandes que l'on veut voir s'exécuter en dernier

  sudo gedit /etc/init.d/rc.local
  et mettez-y par exemple la ligne suivante :
  /etc/init.d/ntpdate start

6. enfin nous allons supprimer le lien qui fait appel à ntp trop tôt :

  sudo rm -f /etc/rcS.d/S75ntp

Au prochain redémarrage de votre ordi l'heure sera correctement ajustée après le lancement de votre connexion Internet. 

Répondre à lami20j

4

Zempachi, le 27 jan 2006 à 20:06:05

Ok merci l'ami ! <-jeu de mot crypté sur 128 bit!!! ; )

intermittent de la poésie

Répondre à Zempachi

5

jipicy, le 27 jan 2006 à 20:07:30

Salut,

Voir aussi : http://www.debian.org/doc/manuals/reference/ch-system.fr.htm­l#s-boot Z'@+...che et Bonne Année 2006.

JP : Zen, my Nuggets ! ;-)
Le savoir n'est bon que s'il est partagé. 

Répondre à jipicy

6

Zempachi, le 27 jan 2006 à 21:02:24

Salut, jipicy
Cette methode qui revient à celle donnée par lami20j me pose un probleme.
En fait, ce que je veux lancer ce n'est pas un service qu'on puisse lancer ou pas {start stop restart}. En fait, j'ai besoin de créer un device via mknod au demarrage et donc je trouve cela un peu trop contraignant de devoir passer par les init & rc. Le coup du .bashrc est pas mal mais pose le probleme des droits root.

Donc, je prends la methode de lami20j sans passer par le skeleton avec le parametrage pour les {start stop restart}.

intermittent de la poésie

Répondre à Zempachi

8

Cyril, le 17 déc 2007 à 16:06:03

Bonjour,

Désolé de déterrer le topic mais je serai curieux de connaître ce jeu de mot, on peut m'expliquer svp ??? :)

Répondre à Cyril

9

untype, le 21 fév 2008 à 11:41:41

Cf nom utilisateur de celui qui a posté le message 3.

Répondre à untype

10

kokzi, le 3 mar 2008 à 13:21:27

Voilà je suis étudiante en bts informatique et j'aimerais avoir les étapes (bien détaillées de préférence) concernant les scripts de démarrage. Nous devons lancer un programme au démarrage d'UBUNTU. Merci d'avance pour vos réponses!

Répondre à kokzi

11

jipicy, le 3 mar 2008 à 13:26:02

Lancer un programme automatiquement au login sous Ubuntu ;-))

Z'@+...che.

JP : Zen, my Nuggets ! ;-)
Le savoir n'est bon que s'il est partagé.

Répondre à jipicy

12

kokzi, le 3 mar 2008 à 13:29:42

Merci bcp jipicy, le seul blèm c'est qu'il faut que je passe par ligne de commande (c'est imposé à l'examen) et donc ta solution est génial mais trop paresseuse selon mon prof tu n'aurais pas autre chose à me proposer par ligne de commande????? encore merci :)

Répondre à kokzi

13

jipicy, le 3 mar 2008 à 13:41:08
  • +1

Ben la solution donnée par "lami20j" au post #3 ;-))

Z'@+...che.

JP : Zen, my Nuggets ! ;-)
Le savoir n'est bon que s'il est partagé.

Répondre à jipicy

14

kokzi, le 3 mar 2008 à 13:42:15

Merci bcp j'espère que ça sera pas trop dur à comprendre lol!

Répondre à kokzi

15

dindoun, le 3 mar 2008 à 15:26:37
  • +1

Sous ubuntu :

au démarrage les fichiers démarrés sont ceux de /etc/rc2.d qui sont des liens vers /etc/init.d
DONC

fais ton fichier monfichier dans

/etc/init.d

fais un lien

ln -s /etc/init.d/monfichier /etc/rc2.d/S88monfichier

c est bon

Répondre à dindoun

16

Djoh, le 26 nov 2008 à 20:03:37
  • +2

Mieux vaut utiliser update-rc.d pour faire cela

Répondre à Djoh

17

thomas, le 21 déc 2008 à 17:18:38

Bonjour, j'ai un probleme,

je cherche a lancer camorama au demrrage dans un script seulement il ne se lance pas.
si je le lance en ligne de commande ca fonctionne mais en rebootant, rien ne s'affiche une fois mon mdp validé

je suis sous ubuntu.

su vous pouviez meder, merci

Répondre à thomas

18

dindoun, le 20 jun 2009 à 18:47:37
  • +1

Salut,

je confirme pour update-rc.d, c'est vraiment la méthode la plus claire, à condition de créer un fichier normal
contenant start, stop ... exemple
créer le fichier /etc/init.d/camorama contenant :


#! /bin/bash

PATH=/bin:/usr/bin:/sbin:/usr/sbin

DAEMON=/usr/bin/camorama   #mettre ici votre programme ( exempel camorama)

test -x $DAEMON || exit 0

case "$1" in
    start)
#ici on écrit le machin pour démarrer le programme genre 
/usr/bin/camorama
    ;;
  stop)
	killall camorama #ou rien 
    ;;
  force-reload|restart)
    $0 stop
    $0 start
    ;;
  *)
    echo "Usage: /etc/init.d/atd {start|stop|restart|force-reload|status}"
    exit 1
    ;;
esac

exit 0


ensuite sudo chown root:root /etc/init.d/camorama && sudo chmod 755 /etc/init.d/camorama && update-rc.d /etc/init.d/camorama defaults
ce qui va créer les liens dans /etc/rc?.d
et voilà

voir aussi le fichier /etc/init.d/skeleton qui est un squeletet pour les ficheirs de démarrage

Répondre à dindoun

19

Alk, le 6 aoû 2009 à 11:50:31

Bonjour,

j'avais le même problème et j'ai suivis les instructions de dindoun, cependant le programme que je veux démarrer à besoin de lire dans un fichier de configuration. J'ai placé ce fichier ("conf.ini" ) dans le dossier /usr/sbin/ avec mon programme, et dans mon programme j'ouvre le fichier "conf.ini" avec un fopen, mais il me semble qu'il n'est pas réellement ouvert et donc la configuration initiale donne n'importe quoi...
En plus de ça les printf que j'ai fait à l'interieur du programme ne s'affiche pas (logique, sinon on ne pourra pas se servir du terminal à coté) mais est-il possible que je les affiches à des fins de Debug?
Merci d'avance.

Alk

Répondre à Alk

20

dindoun, le 6 aoû 2009 à 12:03:42

Salut
mettre un programme sous /sbin est absurde, mets le sous /usr/bin
ensuite assure toi des droits de tous tes fichiers
crée un log pour tes sorties de vérification
test le sans le démarrage système ( il est possible qu il soit lancé AVANT l'initialisation des paths)
fais un essai avec des adresses absolues au cas où

sinon ca ressemble plus à un pb de programmation qu'à un pb de démarrage
regarde quand même avec

dmesg|more
ou
dmesg |tail
au cas où

quant au jeu de mot bah je vais reprendre un café

Répondre à dindoun

21

Alk, le 6 aoû 2009 à 12:21:44

Mon programme fonctionne lorsque je le lance à la main, c'est déjà un point à prendre en compte. L'erreur doit surement venir des droits sur le fichier conf.ini. J'ai mis le programme sous sbin car c'est la qu'il va le chercher si l'on suit le squelette dans /etc/init.d/skeleton, mais je vais faire comme tu l'a dis. Je débute carrément sous linux, donc j'ai encore du chemin à faire.

Répondre à Alk

22

 dindoun, le 6 aoû 2009 à 13:52:00

Disons que sbin est l'endroit où on trouve les programmes système importants et /usr
/bin les autres et pis y a aussi /opt /usr/bin/local
en fait j avais lu /sbin pas /usr/sbin ( qui contient les programmes systèmes d importance seconde par exemple mount est sur sbin puisqu'il permet l'accès aux disques alors que sshd qui est un serveur sécurisé est sur /usr/sbin )

pour les autorisations : un chmod 777 est indispensable pour tes tests
ls -al pour voir les autorisations
chmod 777 fichier
chmod 777 répertoire
chmod -R 777 répertoire ( et ses sous rép )


sinon :
comprends bien que les programmes du démarrage sont des programmes de l'utilisateur root
donc si tu as créés tes programmes ( ou copiés ) sous ton utilisateur normal ils ne peuvent pas être exécutés par root sans ajout spécial
ou un changement d'utilisateur :
chown root.root [fichier|rép]


un petit man chmod et man chown peut être utile

d'un point de vue général, si tu places un programme dans un répertoire il doit avoir les mêmes droits que les autres programes du répertorie ça garde la logique et permet d'éviter les erreurs
par exempel dans /usr/sbin :

ls -al $(find /usr/sbin/ -type f)

tous les fichiers sont
-rwxr-xr-x 1 root root soit chown root.root et chmod 755 ( r=4,w=2,x=1)

sauf quelques uns qui sont
-rwsr-xr-x 1 root root soit chown root.root et chmod 4755 ( r=4,w=2,x=1)
le s signifie que le programme est excutable x ( sinon on aurait S ) et qu'il est toujours exécuté comme si c'était le propriétaire du programme qui le lancait

Répondre à dindoun
Collection CommentÇaMarche.net