- 在线时间
- 63 小时
- 最后登录
- 2019-5-3
- 注册时间
- 2004-5-10
- 听众数
- 442
- 收听数
- 0
- 能力
- -250 分
- 体力
- 10122 点
- 威望
- -12 点
- 阅读权限
- 150
- 积分
- -586
- 相册
- 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) 3 N4 N" G- f# V, ^4 F* j. z# L6 I
; `7 s# [% n6 @7 s* i机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
& ?3 A7 ?) P* R( q# E( L一、linux启动的最后阶段的工作 ' L7 _, N4 e9 ?
4 ?0 m2 f6 y0 q5 @
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
5 l2 N% D* E! N' D5 d0 C% H- l5 _
( _/ t9 m3 o) o, i6 k运行xdm启动X window; 9 X- }4 f8 x4 K$ P
运行gdm,进入gnome桌面环境;
" `: `# m/ n' R- b- q$ Y运行kdm进入kde桌面环境; ( j* P7 Z2 A( f- h! @' A5 X9 |
自动登录进入linux; ! O; z- _' Y- ^2 w8 @1 A+ _
prefdm脚本框架大致如下: 6 U( h& R4 [ H$ q8 \
1 a6 d+ @, r# G- Q4 a7 _" F
#!/bin/sh : p0 {# E- l7 Y/ ?. t
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
+ f& B; f W/ ]0 Z( `" _+ R6 ~. /etc/profile.d/lang.sh
: }; V0 |. X" G# 第一步:查看是否为自动登录 4 D8 f& H3 t4 G4 n7 e
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then / Z* F% G( q% ^3 V/ E
if /usr/sbin/autologin; then 5 f9 V7 K7 q5 M, r' W6 [
exit 0
1 A2 V' L5 [7 l# B) k# Bfi
2 i- Z Z( l, f* D! B Z8 Bfi
% q4 f; }. I3 w7 V9 ^) I; Z
8 T; F! X$ [: d: B+ ?& C1 a# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 : I% M# t7 x' j8 Q
......
& h) v: N6 j0 {9 w- g$ ]# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 9 E/ |# v6 p7 S) r& Z" e* @/ ~
...... 0 A% E& v# F4 s
0 C: Q" [% j- G6 ?% _
! N. H8 _9 Y* M5 o1 R3 m, b% J6 d8 c, @: `0 m% o \
% `& |1 r {7 _二、自动登录的实现(autologin的实现)
5 |; S3 A; S( X; f2 @2 I/ A5 D. R- S3 |3 k0 q% E* D, p
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 1 c+ E& ]3 q/ t: z
! w( Q! z7 j' I2 f
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 + p% @0 }2 b% \% H
$ ~4 o+ h* R( R6 H8 C7 |0 Z. [Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 3 ~! w+ W z( _4 S3 ~
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 # X* L: L( D1 _
startx脚本的最基本框架是: 8 Y2 @) J7 f1 y' }9 G6 `
) w+ H+ s1 Y# A* C- w, F1 k" Na、 寻找.xinitrc,如果没有则使用xinitrc; " p2 @" `6 v3 D* {% a
b、 寻找.xserverrc,如果没有则使用xserverrc;
0 a6 B$ K! ]( e* } ^8 Xc、 根据找到的脚本确定xinit的参数;
" H. Q* J7 G1 w0 U, {
$ D) r# v) X0 \* D) D: N$ F! \由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: # w! G- ?' U( ]3 @' Q+ ?% A
9 ]# ?) i1 p. T6 L8 C
% H, @2 Y7 S% q0 @#!/bin/sh
3 w4 t! H9 L. Y: R/ {% WPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
8 D! u" a/ v j+ }. H% Q$ X; G. /etc/profile.d/lang.sh
S. G, G7 e( d5 l# 第一步:查看是否为自动登录 $ s K, P0 i2 V0 f0 `+ E! @
#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
$ V. O! j; h- Q#注释掉上边的条件测试,直接运行startx 2 l3 j& t2 K# e+ @$ F9 x, A
if /usr/X11R6/bin/startx; then
: O9 @) p' {% m A nexit 0 ! F- S Q) W+ S8 r4 Q x& O
fi
0 R8 r4 V" y$ T; b/ f. V#fi * h+ J6 Z# Y' e% `8 j3 E
9 S; c2 d, N$ _, G j
2 g! o* y. k/ q2 c+ u; z; d
) R. j4 t. Z, b! h
; m9 h8 n" n6 z( B0 E6 `当然,应确保/etc/inittab中的启动级别为5。 0 @ a5 R4 v7 C5 G1 D/ f$ t
) o& K7 w+ L1 r: s+ r重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
& ~6 ]6 q5 e7 R7 j) L0 d. Q" V& _" [) W& t( L, V/ N% }3 c* e* X
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
! a2 F/ R! [% F6 M. o
$ x8 J; p" p# O' S1 h g观察原来/etc/X11/prefdm脚本的自动登录部分:
0 H. O, D, \( r
2 O3 M8 [# Z6 g5 u! ^
7 K: q7 S' U6 z( P7 E...... + Y! O, q% h" v" P
# 第一步:查看是否为自动登录
7 G# B, e3 M7 b$ y* Q1 Dif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
# I# U9 P4 c7 s2 C- Z2 n# jif /usr/sbin/autologin; then 3 @3 J5 Q* X/ e* b: r6 r
exit 0 0 t: ~1 X& [! H+ L) r
fi ! r# }* P G% i" K
fi # R5 w: K0 ?' j" H
......
0 ]+ \$ H0 [( k# V1 ]; }$ k |
/ e0 j" N" L5 |
' T; ?# y# {( B! J# M4 O; D& s
1 H+ _* t9 E1 s0 W
- p: r" N2 F: n9 ]不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
4 D+ t( }- ?$ O0 v3 M/ L; M t
* g2 ]" \+ G: h) j2 @& c8 _# Z1、/etc/sysconfig/autologin配置文件的实现: 9 h6 L; R( | c: I% ~
! @' _1 Y7 c0 e1 R% W. J
6 k6 ~ |$ B4 `0 {. t1 P
#config for autologin
: q0 |* S" J: h: Y, Z, qUSER=root / l/ a+ ^2 u& U* i8 }
EXEC=/usr/X11R6/bin/startx & [! W5 Q2 G& H$ y) A- Z$ @
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
9 \2 d' ~ s% ~) w$ W! z! }4 p% _& F2 G# l, {
" K" y( _. ~! g5 `8 D
& d/ `& E) k+ ?0 e* b0 D1 d9 E2 s- g. U; f+ ]6 p
2、/usr/sbin/autologin可执行文件的实现:
& ^1 D7 S2 ~3 u u: }
% m# z$ ~; A" q6 j, [1 ~
, n; k* |7 m0 m* |6 M/********************* $ W# J2 M* [% O3 ?, ]1 g7 \+ x) N
**** autologin.c ****
8 C! g! M& \, q. h*********************/ $ Z- T; |' U2 ^
#include <stdio.h> , N" F: q$ x6 u
#include <unistd.h> 9 V* ^' [8 \" y1 U
#include <string.h> 2 s2 l; _, F5 M# V9 _$ u
#include <errno.h> 5 V+ L0 Q5 ~2 F( Z
#include <sys/types.h> ( G3 L! s [; O8 `4 z' @
#include <sys/stat.h> ! [& m3 o6 M: e* f
#include <pwd.h> 3 ~) m& L# a$ t5 L9 c4 {
: v* y7 R" u% \* z( e, L' ^
int main(int argc, char **argv) 4 i8 n& ]! o9 `; E
{
- Q. J6 M, V" ?6 tstruct stat st;
6 p. d' @# N/ ?8 ? oFILE *f; + [' y1 Z9 x5 n
char *cfg; * S. {) t: f6 }5 y
struct passwd *pw; ! X/ i" ]9 P' R1 t
uid_t uid;
2 O& j; `7 r0 c+ p# egid_t gid;
5 i8 ~5 s0 V! U" k3 P( }1 k2 Y' c0 zchar *dir, *shell;
9 s8 _0 f# l" q8 ]$ H) I" Tchar *user=NULL;
. X; s* s/ R I$ Gchar *cmd=NULL; $ x0 A) s' E. i1 ]/ e( i
3 o4 a$ ^; ^3 d% A0 P. N; Z. N, P& l
user="root";
" G) _2 `, u' _; d/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 1 O/ w! _# m5 p% B; C T
登陆用户名应该从/etc/sysconfig/autologin中得到, % J! i( W' n y; |
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ , Z/ ^' P) \3 @ t; |
cmd="/usr/X11R6/bin/startx";
1 H! O4 {& _& y8 z/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ / E* e ]% i, L- b0 R
/ E: c9 w* D# Q7 }5 i2 m: I* B
pw = getpwnam(user);
& x/ m( s) W0 c% e, [2 P: `//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
$ X, V7 ]9 B/ F) j r% W3 _if(pw) {
6 _& H* N7 N* j! }9 e q% Nuid=pw->pw_uid; . j. a8 Y3 k1 y! z+ w' L; \
gid=pw->pw_gid; dir=strdup(pw->pw_dir);
; \* P. a3 ^$ e" E6 ashell=strdup(pw->pw_shell); 1 G [, B. j# W/ q
}
7 q9 x6 }# v& U2 X* ~4 b& |//获得用户相关信息
1 v+ Z& g1 |- O- P2 d else { 0 H& l m3 u% l. B
printf("ERROR: No such user %s!\n", user); ! s+ B) @% U, ^8 |5 h8 B
return 1;
" {& w$ ]5 T, d7 S$ t} 1 X! y$ B* ?1 @ ^. o
$ j) @$ O" L7 `/ _$ ichown("/dev/console", uid, gid);
* S9 C) _, x$ A* W9 i+ V' t1 `. o' Gchown("/dev/tty", uid, gid);
, \7 F( [, N$ m' U& C//为控制台和终端设置用户ID及组ID
" ]/ k% ~2 B- `) \& d
# B5 c5 ~/ N5 F3 J- o/ T//下面是设置用户相关ID
5 N( V; T* b& g+ F$ e$ Z4 ysetregid(gid, gid); $ C7 y* f E3 X
setegid(gid); + n0 n) w0 f" E( e/ | s
setgid(gid); 7 u1 `' |, F) F$ }( I% F
setreuid(uid, uid); / Y& B" W7 W+ `( c/ J& q" m1 X
seteuid(uid); - J5 N7 }+ c+ c/ @7 J
setuid(uid);
# n: L4 T- ]& Z; P1 L2 j; M( R1 B; X6 w5 V/ N
setenv("HOME", dir, 1);
+ y$ I$ X5 u( T. [( asetenv("SHELL", shell, 1); ( J5 u9 M6 k9 s: n$ h+ k$ D' k" E
setenv("USER", user, 1);
# }2 Q l; E$ R8 g8 lsetenv("LOGNAME", user, 1); & Z0 L- W" @5 I
//设置用户相关环境变量
. j/ X6 {" G1 N, F& e
4 O9 v# I: r( a" }& m) m5 mchdir(dir);
8 B# F9 M8 I' N//切换到用户根目录
$ c3 F0 r& ^5 a( G+ U1 l! N. b1 ?user=NULL; * S: _) c6 |% T" A# u$ ]% i& J+ W
- x+ r4 X; h& e
execvp(cmd, argv); 1 ~6 ?2 N9 c( K9 |+ i J
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
/ C6 o; ~+ g& j1 ~5 h: H4 Wprintf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); / v1 g% C1 p4 S" V4 s
return 2; 6 ~! t$ [( l ~% \7 w/ ~0 D
} * q& q( m7 ?; _" A- c/ d9 h
2 f+ T5 N# B7 j7 a2 d0 H! i / j7 t, i5 \/ M. k6 N
2 m# z1 Y! k& C+ b9 C/ K: _
4 B" ]! R2 Q/ h% S运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
4 A4 N8 g D& A, \% n! W, J( H8 R E- W( o8 s* }1 l
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 1 ~) E* s1 m8 ^2 l; }1 ~9 m9 D
$ d7 V1 N2 b4 N5 ?3 g
4 B, ~! h/ A4 F! d e4 P3 [# x
......
+ i" P* E6 u' I5 f/ {# 第一步:查看是否为自动登录
. F3 G7 P( o- t7 y3 R+ Dif /usr/sbin/autologin; then ! Z3 f [ p# X. V% i. q6 n
exit 0 * e5 d% m+ [( _& c5 m1 E
fi % ]! ^: S7 K$ N( C! C* n% Q( s/ A
//第二步 ......
; V4 G$ Q! W$ j; @+ ~...... 3 |, f% } N1 d: }
: e( i, ]8 J, J9 p1 T9 w+ |3 @
A6 x/ d& |; m
1 E) s- _. m6 k0 c
. g1 e: I' r1 F即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
( S& K- y6 {0 R0 W% D: {+ `1 @( x9 b0 ~- v4 w9 z2 K+ ]7 t
四、选择进入kde或者gnome,并自动启动X window应用程序 0 F9 t5 L% f* A) A- R l
' z9 ~7 c7 K7 ]5 U: ?- j: k
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 $ e& W3 Z8 x* Y# | N# d" t
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 / }+ Q5 a- q; b
6 S7 O, U- G8 J4 \, K! S/ G' [# h) C$ t
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|