- 在线时间
- 63 小时
- 最后登录
- 2019-5-3
- 注册时间
- 2004-5-10
- 听众数
- 442
- 收听数
- 0
- 能力
- -250 分
- 体力
- 10122 点
- 威望
- -12 点
- 阅读权限
- 150
- 积分
- -586
- 相册
- 6
- 日志
- 10
- 记录
- 10
- 帖子
- 2003
- 主题
- 1253
- 精华
- 36
- 分享
- 8
- 好友
- 1292

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
2#
发表于 2004-9-27 14:27
|只看该作者
|
|邮箱已经成功绑定
如何实现自动登录Linux (Runlevel 5)
N2 c( j3 O3 R! t, v" h" @
4 e" w7 n k" g" r- I机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
/ a& b* C. F Z& ~一、linux启动的最后阶段的工作 % B* e+ p; Z9 y0 P9 ^ B3 V" a; C% v
. O$ d) S3 D1 @) f) o9 @! }9 N
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: 9 B! }5 s. U$ x5 k
' {( W! @. d! P. \) R7 K2 y+ D
运行xdm启动X window;
- U) L* Y& \+ |0 A, H' t运行gdm,进入gnome桌面环境;
: ? F# ^" \6 l, f0 n$ g3 l, j运行kdm进入kde桌面环境;
% F3 q& D. v7 A/ t4 P0 Z0 Y自动登录进入linux;
, W9 E% j" s* E9 s- Rprefdm脚本框架大致如下:
$ R. ?- w. ?3 }' i7 y# U) F$ B' L) r6 v7 S6 m2 [
#!/bin/sh * w# _4 z7 M d7 p/ E4 y
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 3 L3 V, o2 \! \5 g
. /etc/profile.d/lang.sh
8 U7 x' v3 N" U# 第一步:查看是否为自动登录 8 ^: s0 H4 S1 Q# u1 T; F3 p
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
: L& a6 L6 o2 c1 gif /usr/sbin/autologin; then 0 S6 `! M8 y, M- p U8 \5 P# Q
exit 0 ; ?/ @8 ?& ^# S I; @* A9 z% ^
fi
4 m c2 l$ B- }+ nfi
4 E- y% W' {( M _& T! P% s% y
' K, ]0 g1 {' H# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 ' Z) f1 E! [/ o
......
, S8 w+ d9 t! m# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 # L8 I4 ]2 @) ~
......
) U. U( H' X7 i- L; e6 C9 C0 \5 O. v1 m2 W
; j7 c/ o+ w6 t n$ G+ v
% H5 F& H5 L6 c' a3 h
1 Y: P/ e6 U# M) t& Z二、自动登录的实现(autologin的实现)
+ s; H4 ?2 @; Z( H( ~! L6 w& V3 x. O
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
& S5 Z( Q3 W: ]! Y
$ C0 c7 N* ~3 v4 b1 L$ V自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
8 r1 s# P- j6 {) l) k( ~! O9 D
5 N# {# F6 D- v- @& x5 ?Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
/ {/ y3 t8 }- c& D A9 G) C) P- @' r实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。
* F/ ^5 I" Q/ u0 H& rstartx脚本的最基本框架是:
7 F4 h) l$ T: h! ?* |; ?: v3 K- R @ o3 k7 `0 T
a、 寻找.xinitrc,如果没有则使用xinitrc; ! \( O! @( S! ~- A- t. S& P+ N0 ]
b、 寻找.xserverrc,如果没有则使用xserverrc;
- V7 L& L* N+ L, gc、 根据找到的脚本确定xinit的参数;
* f6 J0 j' i) I1 A8 o0 h+ f; {8 D% i( V9 }8 l& W
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: ! R2 R% j j. S/ ?
7 ?# J4 x; a+ h; h- G2 `3 o
M0 p8 O: p* E- f4 F0 S#!/bin/sh
, s) T/ Z3 I# e& }* h1 G" W: uPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
0 z5 L+ G* D8 i: g. /etc/profile.d/lang.sh q/ i1 k' F; h/ ?- _/ B
# 第一步:查看是否为自动登录
8 `7 `" G; \+ O3 W#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then ( j3 [& T( ]* v) M* f) n! ?7 [
#注释掉上边的条件测试,直接运行startx / }7 T: p, k* e$ {2 b
if /usr/X11R6/bin/startx; then
! ~' y' E; S T/ [3 Lexit 0
* k& `. ]5 j$ ^9 K* Bfi 3 l' V& n" ]" ?3 E
#fi
+ r) v, w8 P6 O1 N4 b7 m ~
7 d- F3 ^" v" O; d* P3 J! |. [ $ ^( _+ h/ b& m9 ]# W
8 s" ~8 s) K# G5 Y
; k- g1 L& X" I' p+ z4 K3 v当然,应确保/etc/inittab中的启动级别为5。
; ~3 i' t: c, r" C4 p, Q$ Z) W! W4 }. { |; n3 j$ Y! m; @- d2 N
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
- t& s% r6 a T1 W
6 M) G( ^8 f4 a# u0 ? R* c三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
7 ?, I( \ C- J# F* |) m8 P: _+ w! e# r) `; G6 I
观察原来/etc/X11/prefdm脚本的自动登录部分: . y! V- j" ]9 U& q7 i+ u- _
/ W3 \- y1 A# e- [$ `
k6 V$ B! E% n1 l/ ~* j! R5 `
...... ' ]7 }( z# i! m& m4 M+ L: t
# 第一步:查看是否为自动登录
4 L" u, f6 l3 b. qif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
8 ?3 O0 ?+ h5 U9 _+ r f* @if /usr/sbin/autologin; then 2 J4 M2 H! v' p
exit 0 3 N4 \! K" o9 P3 M
fi
% _1 R2 p, y% I# ?$ e! _' ?" L% C; Z& xfi
: u% f/ q$ u1 I, K3 @* ^...... ; H6 j2 ^4 A$ e9 _6 Z+ Q
. |' n5 \2 c% }) f7 y3 d( U. ]7 C! q
1 H0 y5 C% c! [9 X! z+ v# D( C" R+ ^* s; }2 z, i
: l2 ]" D( ^8 a( a
不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
0 T$ C3 N1 T! c6 i+ M* z6 G
, n& `# N( [2 m$ V; R4 }1、/etc/sysconfig/autologin配置文件的实现: 8 h! s, z. Z7 ^5 V/ {3 s6 O
' ?* I8 D2 w6 l
8 \% _! [- b3 o9 [* [& O#config for autologin
7 E# N/ }1 Q L; _1 _; NUSER=root
. r) y' k; A! D' U5 F! `$ @* kEXEC=/usr/X11R6/bin/startx $ v# p( r. ?( U: F
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
/ d* |2 @! ~) N" M# V: x( M8 ?
! D5 i# J) ~8 g4 _! r
6 Z: G" N8 x5 q" }# J- t; `; Z) p( p2 u- _# N
" q$ W$ W* m2 V6 z# `( L
2、/usr/sbin/autologin可执行文件的实现:
" q8 X$ {9 x. n% a" {; R: R- v6 i) \( g5 ^" M# \3 k* Q
7 `$ x0 C7 _7 u3 R7 f: @7 X/*********************
* t: m7 T1 X9 l**** autologin.c ****
2 f9 K1 J8 a# |7 V*********************/
( R5 Z* ^$ D2 l G#include <stdio.h> " d# z0 t# h& O2 D' _, i
#include <unistd.h> ?! q" ~9 u. e. v
#include <string.h> ' j% j0 d; S. o3 K0 h1 a
#include <errno.h> 2 M. x! e9 C5 b+ N" `. ]
#include <sys/types.h>
+ @, D+ G3 @9 H8 ?! n8 _2 Q" B#include <sys/stat.h> 0 ] R; H- a$ i1 X L
#include <pwd.h>
2 S* t9 b' |" O1 E% t+ g2 X! G7 U6 c3 ^& N( i* y# u3 [
int main(int argc, char **argv) # O$ \: a3 _7 Q6 X
{
* o) Q& t- }0 j! c3 H4 m+ p( u7 i. [struct stat st; * V5 p$ ?" m1 s& O( t3 e
FILE *f;
' B1 g, B9 ~) ]( z# vchar *cfg; / t1 r5 q, p8 `; S4 F. u* T
struct passwd *pw; ; }" y% Z: j! H; n4 R* b2 f
uid_t uid; # T1 [% Y9 E! U6 ^* v
gid_t gid;
) {3 b( v6 X0 E3 ^! O! O9 c4 p+ xchar *dir, *shell; - z7 u- I* V& O" g
char *user=NULL; 4 T) A# t' x4 r% @/ v3 B
char *cmd=NULL;
4 _/ v( y9 t. G" w$ r# V
( {2 n a$ H7 q4 q `user="root"; / o- C0 s% Y) | R3 ^3 O% @" c9 m
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, , w, c3 } j& B' h$ S
登陆用户名应该从/etc/sysconfig/autologin中得到, 0 |* c5 u& u s) E$ h: O1 U4 m; e
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ " W2 R- l/ Z' C. l, A6 m
cmd="/usr/X11R6/bin/startx"; ) n9 T1 d% @& q* \$ i8 G
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
2 S( q. ?9 P, c- U4 x! q. ?
3 c, @6 T2 b+ D( \+ O# u; p0 g) k+ lpw = getpwnam(user);
1 n9 y: b4 a i* A6 |0 ~//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 - h# \- @$ L- E& o
if(pw) { - z& n# A/ V+ x, a7 v; A
uid=pw->pw_uid; ! S) o4 a$ r: a9 o$ W/ M+ k
gid=pw->pw_gid; dir=strdup(pw->pw_dir);
4 M2 k( \* m! X6 ^8 V* E2 g8 |shell=strdup(pw->pw_shell);
- y5 M1 f( |3 O" d& A, t- ?} # q$ ^% |: o0 H2 B/ f
//获得用户相关信息
0 U! ^/ Y- i3 i+ E% \ else { 1 x+ o9 ^& r) @" z, h9 k
printf("ERROR: No such user %s!\n", user);
' U/ o; Q% R2 ^7 e, E/ Rreturn 1;
/ [, T+ I- w/ U. t; a! F5 b- I Z}
8 P, c% w" m) N# q% x7 j+ A+ _' t. S8 C# h$ Q
chown("/dev/console", uid, gid); ( w. v: _: V/ j: ]! A, I
chown("/dev/tty", uid, gid);
1 f# Y8 J- `# S//为控制台和终端设置用户ID及组ID 5 o/ N8 c' j$ X7 L! U/ _) X2 U
/ ?. a: r' F, W1 k! H/ A//下面是设置用户相关ID
% i) J" O A8 `1 E4 R! [setregid(gid, gid);
6 c) N5 M8 j! y7 V0 }0 @2 q1 rsetegid(gid); . b% u5 s! F# I* \) b0 ~1 W9 A
setgid(gid); 2 k! c% Q2 X- B9 {
setreuid(uid, uid); 4 m% o3 h( ]$ U; I- E4 R
seteuid(uid);
/ [/ b# k( F1 h8 x1 R/ Hsetuid(uid);
/ K* b6 `7 ?5 O* |1 f: f. d1 x8 u% @3 V n- ]
setenv("HOME", dir, 1); ! F( u+ x7 ~$ L2 A7 }! A5 w' H# O+ m
setenv("SHELL", shell, 1); h) m% i" f; V) [
setenv("USER", user, 1);
/ h( F$ D) g7 ~8 q4 l. ?4 ?( ^0 Ysetenv("LOGNAME", user, 1); # I4 b( l: Y9 t r
//设置用户相关环境变量
3 J4 I/ b# c0 Z0 r/ T. Z1 B' O2 ]' j4 [! ^1 ~0 |4 t
chdir(dir); # B1 ^/ `! ^( j2 S3 f# K/ C4 p
//切换到用户根目录
) A& o. ]" S9 kuser=NULL; 3 R }3 l$ o7 T; H8 Y! k% p9 u
3 Q4 s1 ]7 Z+ k7 iexecvp(cmd, argv); % ^6 z- H# z/ l& F
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ % T" J" v8 h" y9 ]# B3 V, ]- w1 v
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
7 G: F3 P& N, Z5 n* L' \" Z M* k8 Zreturn 2;
" _0 ?) K$ s4 w! `}
, n d: a" r5 m, v& m' F4 A
2 |' R3 \5 F7 J7 d, `" U8 V
, g% u# ^3 V7 k' m8 e
( C6 M9 g1 l6 c7 T. x: c% w6 ?2 h0 g9 J1 K) x, `& |1 W9 i# `( B
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
: ~( ^2 k; [- h* X! t; c/ x/ }2 K0 M4 f
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: : R5 f& Z3 E1 n4 U
- `! m0 E# b) z" \5 D; Z5 x! H+ U
1 e! p3 P& p- t( ]9 j
......
$ \/ ?1 V- a: l% Y5 T3 K1 d K* [# 第一步:查看是否为自动登录 2 L0 H) H- F& ~% l6 W8 g+ b
if /usr/sbin/autologin; then
+ G v) j8 Q: A& s7 Vexit 0
1 D6 L% q% [9 _3 Zfi
$ V) B5 a; w, m6 Y" ~( {//第二步 ...... * T: h8 h2 O% f$ H0 ~1 t
...... * `& c9 S& \8 C) R2 @
, f& z: ^, ]6 P2 v6 Q E
& m9 x' N0 H! w# D; c; v# I7 u# l- k, w" P; Y/ i% C. A0 c
* _8 @" H R8 V. L' t即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。 6 y4 g) y5 d+ m+ d7 `
0 X% X2 e1 h& H5 q3 q四、选择进入kde或者gnome,并自动启动X window应用程序 + _& f& S+ |) e' `
3 t7 b; `3 p5 |/ P# h D' T, F如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 0 D' j8 e4 a1 ~; u; X
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
6 [1 N$ u0 O2 H; R, g9 A1 O0 K; r; i% `- K: ^. n, e- V* Z
_) |- w2 h# a& s7 W% o7 J2 Q. Phttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|