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

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
2#
发表于 2004-9-27 14:27
|只看该作者
|
|邮箱已经成功绑定
如何实现自动登录Linux (Runlevel 5) & Y2 ^) n1 S. L5 Y+ X" m# p/ ]
+ T& K6 {/ h' Y, T
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
2 l$ X5 Z# e8 o3 o: l! u一、linux启动的最后阶段的工作
' D9 S; Y y0 P1 j& o3 }; N( [) O. L
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: * N1 o) N- I/ f& ~) c
- A; o. c+ o t) y4 ^* ~# s8 t; I运行xdm启动X window;
3 U9 G6 i N% j6 I( d( \* d* r1 D. R运行gdm,进入gnome桌面环境; " i+ T; j1 a7 b R; G4 x8 e
运行kdm进入kde桌面环境;
' \# t. E+ T2 ^0 _# K% k X' `自动登录进入linux; a8 b' B* U, Q9 p( E8 q+ `
prefdm脚本框架大致如下:
+ ]7 c' p. b9 }8 C! l3 ]# v! E! C+ K
#!/bin/sh
/ J/ z1 D8 |, X: E" ]# G6 ?PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin , c! X2 k: ^$ A7 ~& n( I
. /etc/profile.d/lang.sh 0 \1 ?0 p3 F4 }. p; d5 u
# 第一步:查看是否为自动登录
- W# Z7 t$ E) u) z; |7 y9 Hif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
8 F; K8 W( C0 Q$ O+ a! ~if /usr/sbin/autologin; then 5 X) A- @& g' D# i- t- ?2 ^+ H
exit 0
9 _/ a9 w: o2 z1 o& Efi ; \0 b7 p6 G- e7 W' l5 u n
fi - Z; _! w+ w- u* l' y: }8 g* X
: g0 ~- G, ]. b5 | Q% Y" X& e# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
; a$ m- n+ q; |) T......
' ]! m- K8 x2 k# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 4 X" M q+ g9 V' Y
...... 9 e2 U1 \& j4 B. f
: _5 O8 F8 }' \. A+ F
& _4 M+ J# W9 O/ e
' ~" l, s, ~8 m' e/ q1 w+ M& A8 T% j" W$ E; ?
二、自动登录的实现(autologin的实现) : ?3 J4 V/ S; x9 o6 O8 k6 x, y
6 b( Y1 G- T5 i$ J
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 8 G! m1 y# q( S0 Z" K" B: V% M2 {
3 a4 Q( _% q) m6 n自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 4 j, K. ]4 I8 `3 _
o. T* R! n- r4 b: Y5 U6 b8 JXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 : E1 s2 Q( J) u4 L1 Q
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 9 y" U( O! q9 a6 X/ O
startx脚本的最基本框架是:
, h9 Y: ] P, \+ ~3 C \0 c+ T. o( M
a、 寻找.xinitrc,如果没有则使用xinitrc; & G; e0 A; w5 _1 K4 u
b、 寻找.xserverrc,如果没有则使用xserverrc;
' C2 o0 z7 Z' f+ u* |, Mc、 根据找到的脚本确定xinit的参数; + h8 b$ I+ s% f' F
1 h3 h8 E) q! j1 w8 O4 b; y
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
0 x6 F- q Z1 m5 @
/ }- h# K6 y; R) ]! Z
6 O. O/ _9 |; p#!/bin/sh
) P$ C; m G$ C7 ^' g7 P7 f' FPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
: y ~3 r, h" W& ]+ r; S: [/ U. /etc/profile.d/lang.sh + r, ^3 y: ?+ B5 `6 @& \
# 第一步:查看是否为自动登录 5 M) a1 G* k5 _$ g1 b
#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then + u, P# y* w2 ?4 Y/ w, F
#注释掉上边的条件测试,直接运行startx
3 h4 _1 S; d/ P. x6 wif /usr/X11R6/bin/startx; then 0 h9 A! M: {1 {% H
exit 0 # _( F& S+ o% ^; i0 g) e
fi
4 C3 I, H+ f& x5 J3 K, J#fi / S J1 ^/ y- [5 l% E
; |' l0 V' P+ u
* l3 h) i# H; p4 B: Y) u3 }; d# w; u9 j* w, e! _5 o3 E( g
! }: T; I: F4 e" m! R" h$ v
当然,应确保/etc/inittab中的启动级别为5。
: V# D: F7 z9 z2 M
( M( i/ g2 q6 @- g7 I重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 ' Q [- l2 M4 ^
5 D e3 _1 c1 C- Y" R7 T
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
3 a- o/ i' E% u0 |$ R) j/ u2 c$ C- p5 Q" q) ]7 h
观察原来/etc/X11/prefdm脚本的自动登录部分: + n" w3 _. k9 N& o
; ?& \1 D u7 {) d) U' M3 b
$ P0 {) U& z& ^# o...... 3 e- `$ l8 v# v0 E
# 第一步:查看是否为自动登录 ; ]' `4 A1 k5 y' ?/ _
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
8 M* J. l; I8 m4 Q4 ], qif /usr/sbin/autologin; then * e" Q$ n/ g+ |! b' z
exit 0 3 p0 O3 n2 Q7 U. ]
fi / G! k1 Z% S# u; ]: k: b
fi
+ g, S7 f/ F0 `# u: I...... 9 S- t4 [9 P$ i2 f, D" e
T) w4 I( t; Q- d/ |
0 V$ _& L! m) v- a6 q Q
3 o% ^, n. { u* Y$ N# Q% V
9 B3 Q$ t3 N& e- M) B不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 - e' q# C# [- m8 o) w/ c' C, U: N
" L/ `5 l" J+ Y* J" G5 H8 ? g1、/etc/sysconfig/autologin配置文件的实现: * J3 k: \2 T! v! e W- ~1 t9 N% D% [
l5 b9 { m/ C5 k C+ s+ n# \0 w7 ^8 B! O- l
#config for autologin
' M+ p6 J; y0 h, R+ rUSER=root 0 S1 w4 }6 N7 |& K1 v
EXEC=/usr/X11R6/bin/startx 8 ^; F, e. }* S
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 a& A Q% k& O' K2 `
8 [" r) ]/ |% J
# q' t, o% ]; n z) m' d6 y
1 Q9 `6 i/ U, \7 K
: z/ \7 J; u5 A6 T" u2、/usr/sbin/autologin可执行文件的实现:
* g; p5 N5 r! U# {! @5 M. U1 k
1 a* Z2 C/ y& ?0 I
- X" i/ u4 B, O/********************* ( d9 G8 p: b% m2 p- h
**** autologin.c ****
& q/ O8 p; C1 N& q) U*********************/ ( o: O( k4 u8 B- Y4 D2 ~2 W' O
#include <stdio.h>
9 m) s- b# T- p: q4 X) k#include <unistd.h>
( F) O% H0 o c$ l, R/ r3 x#include <string.h> 9 F( B4 m5 P; u8 D2 B7 }: Q
#include <errno.h> * W1 m$ I9 ~" A- Y2 |
#include <sys/types.h>
# ?: N1 A# [1 w5 k# c#include <sys/stat.h> * Y6 |: S: c3 J$ p+ g1 B
#include <pwd.h>
6 E! T( g7 b& H, Z6 V- o' t( ?+ q5 S$ q8 U
int main(int argc, char **argv) 8 J& I# R2 [- s3 X8 S3 D
{
- ^; e3 _6 {$ m! }5 Istruct stat st;
/ D9 ]. a5 {: @+ V- q. T9 [FILE *f;
; j$ b% I! [; r2 _. Z$ \char *cfg; 9 } U( |, x0 J; L2 p; J
struct passwd *pw;
5 s* H4 A. t: u. ?& euid_t uid; ( s, M d% U* A- h2 {
gid_t gid;
8 {$ q/ y) J+ U) hchar *dir, *shell;
~5 v$ @: N, I/ J! O5 |' S" w' E2 Dchar *user=NULL;
8 h4 ?; X8 g7 A) E' x7 `& M* ~char *cmd=NULL;
1 j1 w+ B! X3 H! L& a) F- f2 P0 B: f8 k. Q
user="root";
) B9 g9 Z% l/ D7 Y! k6 a9 k$ f- v$ l6 |/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
. {( |. Q2 U. i2 T1 t- A3 `- T* J登陆用户名应该从/etc/sysconfig/autologin中得到, 5 |% \. K5 u% n) P* K. c1 O7 X
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
7 ~3 n1 z! H6 }# Icmd="/usr/X11R6/bin/startx";
: l8 J) p+ u u' C/ U7 |) K. @/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
4 \# _! |+ s4 s- i
$ t2 M+ T& ^7 U: ]pw = getpwnam(user); & U! ~/ i2 x/ d' i Q
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 / n0 ~$ o; i. k/ j* f C1 q
if(pw) {
# W9 x# F( w2 |! R9 O# p4 b% Luid=pw->pw_uid; D* d: G! B/ K7 j' Z$ b
gid=pw->pw_gid; dir=strdup(pw->pw_dir); 1 v+ a; ]6 e6 G2 @
shell=strdup(pw->pw_shell); 2 j/ b1 E4 E0 p" E1 q A3 |
}
9 Z/ t0 P" `4 o" a8 g; ~//获得用户相关信息 0 U# R6 U+ D; X9 A j7 K* C
else {
0 J+ U2 K. x( d% Y. _% Pprintf("ERROR: No such user %s!\n", user); C, A0 c1 G# _% k
return 1; 2 m6 u9 m$ W) l% S; W& M
} , h; f5 B# |0 ~; ^/ R' {) [
1 Z6 H' S$ Y! x9 Z: Q; ^
chown("/dev/console", uid, gid);
J+ t3 R( g! z0 l# cchown("/dev/tty", uid, gid);
: _ K3 Y* m# C' l, ]. {+ l) y//为控制台和终端设置用户ID及组ID
1 K1 Z1 i* C" N' x1 u# [* S& H* R- L1 N7 E0 h; x% U8 Y
//下面是设置用户相关ID
) G" Y( I8 e9 \. usetregid(gid, gid);
1 ~% _9 p! K8 Z* O6 O- R% y/ Qsetegid(gid);
4 [6 V$ V: G! N( X# f4 bsetgid(gid);
; @& |; Q2 w) [& msetreuid(uid, uid);
U9 `9 Y: K# L+ n/ ?/ \% cseteuid(uid);
8 t9 D& Z9 U6 q! ?6 Q L! G8 esetuid(uid); & [: y4 F: K. W* Q$ l w
$ C* h; y& `) [. e: p* J* a8 Dsetenv("HOME", dir, 1); 6 Y+ j# E) k% q0 G/ Z& t3 G* F
setenv("SHELL", shell, 1); 1 d$ Q! L8 l9 Y7 Y/ l& ]
setenv("USER", user, 1); 5 r t2 }$ ?8 \ y/ [3 y
setenv("LOGNAME", user, 1); b/ m, v6 ?7 \2 f, {- _
//设置用户相关环境变量
' A7 |3 E4 M% O$ z2 |+ C, l; y; |7 J
7 p$ R, j2 l# }8 ]: }' zchdir(dir);
; P- J. g/ s; Q4 s7 ?* A" ?//切换到用户根目录 ) k/ r+ ^) G1 f s
user=NULL;
W2 n- a( P- V6 @, d1 e7 n; z) a
execvp(cmd, argv); * w& f9 S9 {9 R9 ?
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ 8 y, `6 {2 r' t' i. k
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); % j; _5 F2 T$ x5 B p
return 2; 1 C. N5 X! s% m0 |
} 3 V+ d( l* M6 d
( _0 Y3 I' M: E$ S4 f
% C5 B2 O9 z- [$ ]2 F3 w
; S9 r, l- _7 U# W5 S% z
1 m* S" D! ?. b r% B+ O7 v$ ?运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 + z: z# f! p+ r# s! q
, S+ g/ P1 {6 p$ y/ Q如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
& m* ~% Q- k% x9 T# {- |9 g: N; V" a
" S' y1 Y! A5 Q( B...... ! O- `! |. @' d7 Q9 k, ?5 h
# 第一步:查看是否为自动登录 & H9 T" j) ?- F8 g1 x
if /usr/sbin/autologin; then
4 _5 S+ J1 @+ K4 K7 wexit 0
' r8 X$ A% i, m9 S* a6 _7 afi & }! L- P$ A& {! o7 R
//第二步 ...... ' I2 ] \! r K$ ?5 Q' s; u0 Q& A0 a
......
0 L4 d- J# S" V f! Y( ^) v O( H" ]' W) Q
4 P2 U" B. r( i" f3 l; ~+ E) Y/ u8 B. C3 @
( T& F" \8 }9 Q$ R# c即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
: i1 b l; B/ ^8 ` J7 Y/ f9 o- R) T/ E7 N: A9 Z S5 K
四、选择进入kde或者gnome,并自动启动X window应用程序 9 l! }8 Q2 W% i
( _, u& o" z) b N0 ^2 A0 _如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 + Z5 h" y" Y) w, b' g
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
% o% F: B# X0 x/ Z2 v
1 g8 h+ ]. {' A3 K- ^/ M
, A, `) d9 y4 v {( nhttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|