- 在线时间
- 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 V, c9 a. s) K9 A. j8 V% E+ L& s- @: X; R4 P& i6 A# w, O9 v
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
5 K5 C8 t# m& H3 N, h5 S( g( Z一、linux启动的最后阶段的工作 Q. m4 Q- C4 E
4 V# M' `8 K3 q' z% ?8 Ylinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有: 5 z8 j1 ]+ o. O
) [% I+ W. X: b- S3 [7 y9 G运行xdm启动X window; 5 G8 c0 K- n6 J2 b! z
运行gdm,进入gnome桌面环境;
0 B# r @7 j6 z& M运行kdm进入kde桌面环境; 9 j/ H1 m" X2 P0 O+ K6 v1 e
自动登录进入linux; : e% ]* V' H! j. t7 L
prefdm脚本框架大致如下:
9 v% e5 e" R2 E2 ` j E8 w1 D
7 p' D. k( R a#!/bin/sh 4 ^) \" Q [ T) v
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
; R- A7 [+ f/ C6 O' \5 }& ]( I. /etc/profile.d/lang.sh $ L0 T. w! x8 C8 i5 f
# 第一步:查看是否为自动登录 ' G. O! `. s9 O4 }! k% N- k/ h
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
6 P$ ^% ?1 m4 R. P7 D* Pif /usr/sbin/autologin; then 6 G; j9 [$ O' `
exit 0 * e8 E7 w5 n/ l6 d% {$ R" ~) [
fi
( w/ b1 V [; O6 k( [- N+ ^- @fi " V" j @, ~. m" p2 ^
( i5 _6 k @' ^: b8 X# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
% |7 O- Z% o' E+ a0 w6 c" H...... v9 V+ W+ T* t5 J3 Y6 L2 m: A
# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 3 V6 N, W5 P7 g" u, L/ O# b, _
......
, L8 v% G) W- u% G! \
# \9 n/ B9 U' S6 C& S+ k. o & J3 J+ v6 E. H" h% P' z( G9 c
9 r) H' K E1 K" p& j
- Q0 D) Y) {& k5 Z6 L! z二、自动登录的实现(autologin的实现) * i3 U1 N' u' k: Y# o
0 a1 z& L% M9 Y- O/ O# {6 V" [
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 # ~" E! c+ Z$ s2 ^, v
, G/ V: g) m- u2 h3 T
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 & U( x. m& `$ Q5 V b c, n" z& ]
2 I( h( K2 H4 Z# n1 j, ~Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 # _/ a$ Y1 D4 u1 T
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。
, E2 Z* s. p, K) [startx脚本的最基本框架是:
$ F: g( C+ j. c3 b B; U- b% y. |$ U; `' M3 }) I* V( C
a、 寻找.xinitrc,如果没有则使用xinitrc; 7 s- T: i$ g- y$ e- R( \; d. @* t
b、 寻找.xserverrc,如果没有则使用xserverrc;
" ` m: ]( _9 d8 cc、 根据找到的脚本确定xinit的参数;
. m, ~2 w1 q" @; t: p" M$ i! f1 B% m0 ]
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
) S3 E" l/ [! f: s) Y
# R! v8 P' Q8 O3 A, [* W. \" g+ {& r4 I6 L8 S+ l2 s, Z
#!/bin/sh
5 X4 v+ Q3 y; D; p# \, N2 vPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
% ]6 t/ A' _9 \8 X. /etc/profile.d/lang.sh ' t; ?* b5 |5 }' y- V
# 第一步:查看是否为自动登录
( \8 n8 G/ O4 }2 l4 M#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
! j4 F/ q* b0 E$ T; g#注释掉上边的条件测试,直接运行startx ( T, V! X3 C* v% |
if /usr/X11R6/bin/startx; then 4 h) f! D% M5 E
exit 0
+ f- F, A' s5 j$ c m$ A! |fi
+ v+ A4 `1 g6 Q; z#fi
/ o3 A% o2 _4 h4 g5 o; l8 D( W4 @- q. S- ~
7 I8 z# `- e8 R" P# J2 {8 `
# c& H7 z& }) _8 Y2 P. C f
" A$ c5 p3 ~7 |当然,应确保/etc/inittab中的启动级别为5。 + n8 H( ?: I' B7 p U$ M/ T
7 n" Y6 Y) N+ x! P" M; k
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
3 s& I+ N) e A( H+ }6 u: c2 k+ W9 n3 V2 N; m
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 2 U! N2 P( R$ M4 s- Q5 Y
+ s/ J) w% H# _% a' z6 n$ H
观察原来/etc/X11/prefdm脚本的自动登录部分:
* i" e; P; a: C9 H5 x: K/ l! |2 V0 M O4 u9 v4 F
3 Q8 {7 b, |8 A/ C1 N( a3 H$ M...... * u2 M- d! ]& ^$ ?& Y0 H5 z- C
# 第一步:查看是否为自动登录 3 x/ C$ e' O& J4 z
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
6 C( `2 D. A% F1 }# ]( v* |/ t+ rif /usr/sbin/autologin; then
& M p' J( K- {- A/ ?1 p- w6 Vexit 0 ?4 u( \& a; G
fi 1 B* M% o. y6 h2 X: ^# I9 r
fi 5 T" {. }. b8 z
......
! r5 {3 _4 `2 |+ H, j+ Q" d
: h8 ]* G& F% `5 F8 W
$ M5 x% I8 D1 z k2 E/ Q4 l4 @; C( i+ \
/ p3 f: h' J) \" k* }) w: ?不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
; c3 W) F7 z8 ~! h7 i" Z7 M @1 Y+ M: E1 `
1、/etc/sysconfig/autologin配置文件的实现:
* s3 n. \# s5 ~' Z2 Y4 I0 @" b+ N" @ M0 k
' G( X0 M' H0 Q; ]#config for autologin 8 o, ~. K/ A+ c* I
USER=root 4 E. p* P4 B( I* H
EXEC=/usr/X11R6/bin/startx
" d9 r( H8 M+ b( K- e& p说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 . r3 K3 y( Q3 v5 K
* u8 `' B% u) m/ W( W) |0 C
$ r: O$ C: `# S/ R0 c) |1 a4 q$ [) U
1 @1 r8 w- }6 N; j
2、/usr/sbin/autologin可执行文件的实现: 1 H# | D+ Q0 [4 _, e
6 `( |, F9 S) m8 M$ Z4 G- Z
, N* T& N- S4 g c% X9 ^
/********************* 6 c% n/ A* m+ q4 X E& i
**** autologin.c **** " ?+ e( h4 @* c5 k" u: ~* s5 }
*********************/ 4 A* b6 E" J) `; @0 N1 a& A( Q
#include <stdio.h> 9 m) j( N: l6 Z
#include <unistd.h> " h1 G( d3 {% R" c* s8 P: m! ~
#include <string.h>
2 d+ Y0 W/ Y0 Z6 ~ N8 y. ?#include <errno.h>
9 v0 V6 o' G" _ |#include <sys/types.h> # I+ Q; ^1 z* |9 R- n
#include <sys/stat.h> - D5 P' I7 d" l# G9 o2 @4 a
#include <pwd.h> + s7 [8 a0 S; |) y
( r8 M6 r3 i* E7 }! Gint main(int argc, char **argv)
! Q% `1 r3 o+ e4 z% U/ u{ 2 j8 |7 P$ g$ f
struct stat st; ) Q6 j$ R8 L2 _/ f Q( [
FILE *f;
1 |* c' V5 p+ M0 I; E3 zchar *cfg; 2 W5 q. y( q' a. L
struct passwd *pw;
+ Z% r4 C- q6 q Auid_t uid;
- L+ X$ D% q$ y, I: g6 cgid_t gid;
: J9 r/ Y" Z* U6 a8 ?8 lchar *dir, *shell;
6 O: i6 `. G: S& ^1 achar *user=NULL; + [% l9 ^" t) B
char *cmd=NULL; : r4 T. s: c+ E, T/ \3 i5 i
# n5 M0 ^ \) y/ l
user="root";
9 h. V3 A* W4 r8 a7 L0 F# ? r/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, . D# p. |7 i' |! }; u5 i5 u( D# ? n
登陆用户名应该从/etc/sysconfig/autologin中得到,
8 Z6 B& }4 i, N0 M `: C程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
) V( W+ R; V. M" U5 r/ ?7 kcmd="/usr/X11R6/bin/startx"; X1 l) X' X. X, m$ d. i! L. r( E
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
7 _7 I* M9 A! g8 s6 Q |% l. b* @8 O, H8 Y" L6 y
pw = getpwnam(user); ) O! ^) R) b8 x' \8 _& }1 i# Z
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
" s4 T# z. K2 K, F# d: C* hif(pw) {
2 d& c' S5 h/ j7 {, W8 [uid=pw->pw_uid;
" x: L+ B# z7 hgid=pw->pw_gid; dir=strdup(pw->pw_dir);
' P H$ {+ D9 A9 J8 S3 N; l6 s$ H1 gshell=strdup(pw->pw_shell);
7 ~, I, Z+ R/ Z$ |}
% ~& Y$ G+ I$ |2 D//获得用户相关信息
/ _ a \) ~ M' P9 g. B+ X5 G5 b4 c else { " l! X8 k$ B* k: R1 E& V
printf("ERROR: No such user %s!\n", user);
; s8 T# y7 y8 _) l& v' [return 1; ( n, j w5 s' a' w0 y+ F
}
. K, T/ i) b9 L1 u7 L
3 U6 h: t9 ?; B8 Y9 Pchown("/dev/console", uid, gid);
9 w K3 _3 c& b! c9 E, rchown("/dev/tty", uid, gid);
# A: N) U- a" g& \: a: `7 y//为控制台和终端设置用户ID及组ID
, L- `. {; E: b7 q' T# N: n
& y, n* `; ~ C/ S% w, T! T" y- C//下面是设置用户相关ID * B, b& G6 u8 w) r
setregid(gid, gid);
- g/ j }. s% ?setegid(gid); 2 c0 I+ x" D$ T& G
setgid(gid);
0 v: v W& }: R( Z* zsetreuid(uid, uid); 7 y& `/ ]* v6 q
seteuid(uid);
( C/ ?) w4 t9 dsetuid(uid); 3 t7 U6 J, U1 B! t ?' W. P6 X0 ~
5 Z( A4 U3 f: j
setenv("HOME", dir, 1);
% S- w$ ~, ]7 w$ E8 D; x7 ^* A6 Wsetenv("SHELL", shell, 1);
' s3 T, r$ n8 R) l m$ csetenv("USER", user, 1); 0 `: \/ E3 S6 V$ |4 P3 P
setenv("LOGNAME", user, 1); ) {$ A. C$ U* [" p1 C
//设置用户相关环境变量 7 d) b! i8 g! l! |; o4 f# D' H
/ t: m: l9 A; P6 y$ m# f/ Q
chdir(dir);
( s0 `' d z( p c/ \1 \; K* l//切换到用户根目录 1 b; Z6 b# i2 s! X) `6 @
user=NULL;
) r6 l, }1 j! ~5 h" V
) Y5 ]/ [% b$ ^! |) Rexecvp(cmd, argv); ' F; E3 s3 `6 C
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
5 B/ J0 v' H" D- _printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
+ T, z; P2 V/ l6 T7 }! breturn 2;
% E0 n6 f7 q( I5 m3 K} 4 P& X6 H5 [: O; K8 g, ] |
0 o% b; v$ L5 r$ G* O( s4 l5 a
$ e; r% p8 p( Z9 n" I: d* L H) W9 U) u M7 [" H
, I/ I$ y. \7 I! L4 w" m0 S ]运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。 $ R5 S( H9 H U) m& E
4 G+ e; `" h K" z. Q+ d- M
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: # L( K- E5 G. t, D) q3 w9 R
8 j% y9 B2 U- e( r8 l( z* C' ?5 _) s7 l' n( X
...... 4 L( `+ d3 Y6 K! Q
# 第一步:查看是否为自动登录
6 d5 X) O( v0 b& r7 [# K/ [if /usr/sbin/autologin; then % x; |- ]6 h5 y
exit 0 0 f7 ]" U: |2 d8 ~# |! m
fi , I- u% n! { l* G( M3 \9 c
//第二步 ......
5 x! Z! ^; U! ~) l) X9 I...... 0 j1 Y/ B# T0 M- `& w3 D3 A5 h
1 F- |$ C$ ]2 R. ^( T0 }0 s
+ e0 O/ U3 Y7 a0 p) Q* A
1 H) o1 V/ o4 E1 G2 Z2 [; x. `; d" v! S+ a
即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
7 r7 Q, p9 B j& f# s. a4 @
+ T+ o {+ ~. |2 ?" S! ]+ R四、选择进入kde或者gnome,并自动启动X window应用程序
( S+ {5 m2 y9 H1 |6 c4 A7 D) _0 d3 p1 F1 N" t6 e
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。
- c/ v% l7 W8 h+ D% ?一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 # _8 i! u! J# b9 B9 a/ \
2 _3 L" a Q' x3 o" n4 ^$ P
& `6 X5 X! G. I1 y. f' c% thttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|