- 在线时间
- 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)
2 T) ]7 ]. s) [) J' R9 u) z3 i8 W" o
: g4 Z# F3 ?- q# m机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。 7 w& o- \2 m2 W" ^3 l
一、linux启动的最后阶段的工作 4 v" [# ?4 B* E; J( g- l p& u
, z1 ^% M2 w6 olinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
( a$ Y7 y4 V( X; A# }, d% |. w. w3 ]9 P6 J4 ~- x0 y9 o8 E
运行xdm启动X window; / E& h. B( X( l5 a& F, L* r
运行gdm,进入gnome桌面环境; ) G0 G. j" f- J7 b& q+ [. M4 T
运行kdm进入kde桌面环境;
: I7 y9 V/ h0 i' d自动登录进入linux; 6 k( Y, Z( S% T" Y/ {
prefdm脚本框架大致如下: * b& N& A/ m6 k: m: _9 c# E
! {1 M' V1 ^' \& S7 o7 l#!/bin/sh ' h7 X( a& K# k4 D
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
9 H P Z" K: m" G) x. /etc/profile.d/lang.sh ) v& y! H+ X- _ o D4 ^: \
# 第一步:查看是否为自动登录 % X) @0 `. N$ Q, I3 d, I2 d n
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 8 L7 V. k/ n6 ^" i7 u, v& Q
if /usr/sbin/autologin; then
; G; q6 N, o# dexit 0
* x8 I+ N5 H* E! t% K' Zfi 0 M3 ?1 q# T- ]. Z; H8 u4 W1 ]0 ]- w
fi Y" m- q9 E+ c* E1 v& ]# E- w+ S( p
1 P6 s( ~* \, o+ I+ @3 l9 c
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
, x9 ^0 g" h# i' g8 G......
2 }) ~ D1 ]6 |8 p# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。
+ B* h# T/ i: y: X......
5 B$ j6 r" E) y8 O! a8 G" _( u: k' {+ r7 c2 k+ ^) `: l6 F9 b1 X% U0 s
. Q' e" b, U% I- ?
; J$ q" w, q) J" R4 K3 Z( @9 J, R2 \9 \+ C; C( o, I4 P- r0 g
二、自动登录的实现(autologin的实现) + @1 |, B7 X% A) w4 x' @1 K, n* J4 \
* B8 I( S! g# { X
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
/ u3 X3 q1 n! M" z1 U+ [5 `5 a( \) |% f( u( }' M5 L3 b
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
& [; o# b8 W0 J+ l6 Y% e$ F4 {, E8 C, I; U( R; [6 B
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 1 j+ h5 ^" F, u9 r) t7 `) t
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 1 ^/ t3 S4 c6 ]$ r
startx脚本的最基本框架是:
$ i" p! ?% \; I) K# m/ g3 @8 g* `- K8 f
a、 寻找.xinitrc,如果没有则使用xinitrc;
: }4 i6 r" |3 ], \) Mb、 寻找.xserverrc,如果没有则使用xserverrc; 4 A* S- T% _7 R2 [
c、 根据找到的脚本确定xinit的参数;
; Q0 u* l7 H1 J+ C' T" N
, T! a9 q4 |& _2 O由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: + }- `9 m7 N+ W- n- M8 y" V5 V
% q& B, ]% e" F: Z
@' b$ Z7 m: Y, q#!/bin/sh
_8 ?9 z# t. E( P& K: i7 M `PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin ! R4 `& @/ {* D2 n: \* A% q
. /etc/profile.d/lang.sh 0 g7 L# {; _, n/ z. i9 \# R& g
# 第一步:查看是否为自动登录
, \% ?6 Y7 v) D4 c- f5 f#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then " [+ G1 G, k1 c. i0 t/ P
#注释掉上边的条件测试,直接运行startx 2 z+ p- v* M3 I9 s
if /usr/X11R6/bin/startx; then
! P8 j* A& H/ f }exit 0
' a( g% d: J6 i/ z! Nfi 6 x* \1 L4 }! i5 Y2 F0 h
#fi / X1 D) \1 h. R) s
8 w/ E3 M& j u# i5 q, g K ( Y4 e+ ~0 c. D2 U, x
/ f% k) ?/ i! Z
7 f. O5 F, I* l( ~9 `( [3 d& i# j; ?当然,应确保/etc/inittab中的启动级别为5。 ) A7 v9 w6 L0 W- F# u/ c! n
$ ]' I8 G! d1 P重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
, |: E* _6 t O' _! I7 L
3 M8 j1 H. H9 t) E& ?1 E三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
; i( Z1 n( X# U# E
: p0 r2 i% r5 y' v2 F观察原来/etc/X11/prefdm脚本的自动登录部分:
( ?- R# [$ q5 h
+ [9 q+ W8 v8 N( ~
7 R. L1 x+ `" |4 B" _4 e...... " N8 T: G# ?+ [$ A
# 第一步:查看是否为自动登录
8 w! b+ l( w- G0 M$ eif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 6 D5 s8 U8 ]! a* H
if /usr/sbin/autologin; then # D# o0 V, q$ n6 B. E! |! W
exit 0
7 D' ` \2 H% e* Ufi + F5 |- B! V# p( ^; T5 s
fi
# T2 i0 @8 t3 t...... 1 J* W, M3 G# @7 W
2 ]$ r! @' y3 D4 s/ u
' @' L1 F5 ^: h, j+ A) x
' u) ~' p) T+ ?. B
; ?* f( G2 y! Q; S& Q; e2 X不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 ' N) q5 e! W% D
1 N( ? r3 n# I) J0 C! M
1、/etc/sysconfig/autologin配置文件的实现: * E4 g3 `: J Y8 `" ^# b5 A
+ r T' J- ^4 C/ m- g1 l3 Z- G* s
#config for autologin # L0 |6 f6 {* X2 k
USER=root
& |- Q& P9 y8 }6 ?, I/ f3 ^0 I1 dEXEC=/usr/X11R6/bin/startx 5 x( u1 k7 l% I6 k! Z6 o+ D( w
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
# o+ {0 h1 I3 q
$ K/ o6 U# ?; I( F4 C L " r/ b8 f( u7 ^, h+ `# K
( F! o# U0 m4 Z; c( h! A" J, c
8 m. ^2 ?. i3 g: h- d% ^$ c2、/usr/sbin/autologin可执行文件的实现: 5 X; H: f, h v& g0 b
; `: V) c& z* s9 z0 U8 T! n/ Z
/********************* 8 w; O8 B0 }1 Y6 ]
**** autologin.c ****
7 I A) S, q, c5 t X*********************/
7 v; {0 x7 x: O9 Q0 \#include <stdio.h> # u D9 C$ G- m" D: S
#include <unistd.h> 8 i! i# J! D1 P- _2 J( l7 q
#include <string.h> 7 F& [" m' S$ b* _6 f( a
#include <errno.h>
, a: n3 e1 Y: d7 x#include <sys/types.h> ? ~; U( d) y+ m- V5 @6 p
#include <sys/stat.h>
* s0 z2 J( d; N2 X, s0 v#include <pwd.h>
& y' V* W: ^1 |, \: g+ |% k r0 a2 u' f, H' s9 g* _9 G
int main(int argc, char **argv)
* Q- N! A7 x' P{ 2 N8 R7 `! X1 F
struct stat st;
9 p# P; z1 i7 Q, g- S( vFILE *f; 1 i' S; H* L F$ M
char *cfg;
$ }% \" ^: L% A9 p! wstruct passwd *pw; . ~* F8 v F# e i6 w" J
uid_t uid;
! a: ~ O) P; u1 z" Z% o5 ]gid_t gid; 0 k. e" C8 x7 c8 g) A
char *dir, *shell; 1 o9 k% L! Y; p1 T6 j
char *user=NULL;
9 Y* t; d1 G. w4 P4 dchar *cmd=NULL;
. \* l' ~- M9 o6 B# w9 x) H2 r
user="root"; , M: u1 W% }8 f
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
; P. I2 b, K7 v' O c登陆用户名应该从/etc/sysconfig/autologin中得到,
# [' r. f" M$ d: ^程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ % P' _' P7 x2 B, C
cmd="/usr/X11R6/bin/startx"; " Q) F5 P* S6 S8 c$ I/ R7 g
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ ' {$ U# D6 a! ^( U" l" V
: S3 b9 R6 W9 r8 c" c# K
pw = getpwnam(user); % c' q% w6 O( t' Y4 d4 ~0 Q+ p
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
5 A3 S# x) B; B% pif(pw) { : V* [$ q% T' i5 p( O! Z( ~
uid=pw->pw_uid; ) c1 c" Q% M6 ^% @/ i" J5 ^/ u
gid=pw->pw_gid; dir=strdup(pw->pw_dir);
! C# b/ ?5 m) Nshell=strdup(pw->pw_shell); K3 K. Z3 n: @
} , R( d7 }$ {; \9 ^$ P5 `: k
//获得用户相关信息
$ A' p( Y# i# F L3 f& V3 j3 W: L else {
& f) y# W' {* f- a2 S* [printf("ERROR: No such user %s!\n", user); 5 `; k9 @6 {& {: z* v; N
return 1; ! m) |) o* \% W# Q
}
+ k1 A ?& _7 C$ H. a$ ?# V& I$ u+ K( _
chown("/dev/console", uid, gid);
, Q1 T0 j& s* d1 v! f7 schown("/dev/tty", uid, gid);
9 ]8 `# f/ _6 d, r6 U2 `# C( b* _//为控制台和终端设置用户ID及组ID
( ^) n& ^4 t& K* g
/ R% F' q& M" s* k; l% J6 v//下面是设置用户相关ID 1 C* Y$ t0 p$ R/ ?6 L
setregid(gid, gid);
7 J$ L6 N, R# P* t+ Lsetegid(gid);
* C4 [. U" A3 Nsetgid(gid); . S( o1 k9 D, ^+ K6 S
setreuid(uid, uid); / |* T1 A! E6 q8 D0 b
seteuid(uid);
% e2 Z/ |- [( S2 O6 T" P Hsetuid(uid); & j+ H1 k! r3 x# l A; a
: a8 j) c3 ]- O) |- ^3 s
setenv("HOME", dir, 1); 4 `9 _& N2 R. O: V
setenv("SHELL", shell, 1); 3 e% h4 R+ i( E7 T6 z" Q# l
setenv("USER", user, 1);
6 M) G$ U' J* [3 F }) Psetenv("LOGNAME", user, 1);
& F- C; Z6 A7 q* Y) L/ O; A//设置用户相关环境变量 8 p$ u, X2 V+ I/ v
3 j) S4 V8 i! z% ~5 m$ bchdir(dir);
9 C$ C- j h' b2 L7 l$ @//切换到用户根目录
; q) v( S& _6 Yuser=NULL; ' l% }% q5 `8 b) l
7 W* ?' l( Z2 U* ]# _
execvp(cmd, argv);
9 C2 P3 z& M8 {/ c/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ 2 O" m) w: _: {! }% W
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
/ E; j+ j1 ~ l; dreturn 2; , j1 k5 R$ V) W
} 9 u* f; H B" F, ]( M! S! H/ f0 T
8 x3 j% x- `! M' k" B; H) a" U5 O3 X / v5 G& d; v9 ]8 O$ F! t {
6 s: G7 z9 }% P2 F7 p% b
% g; D; \& n4 F- S9 i/ R+ l
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
1 s! \, \( i7 A: {( v: h+ z; e1 e2 {0 |0 O' t4 _, X3 n
如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: " `. Z) i; B* z
, x2 d0 V) V2 z6 _( c
4 ]4 R( I1 Y" r+ A+ ^# ?8 w
......
: M0 m# i8 I4 r' |: V$ C# 第一步:查看是否为自动登录
4 f6 C6 L7 F$ d5 ~; R0 V7 m# qif /usr/sbin/autologin; then
k! F, W R& K) t& i; Sexit 0 3 q! p4 k+ e$ L0 V; V) @0 u' ?
fi
, P& p$ I6 P$ ~8 _* z0 d1 [//第二步 ...... 7 A4 J; d' [! A, Y H
......
! E+ l4 B- f0 ?& Q# Y n' Q
( E: x7 p- t9 u$ W; y
) N) B- J' b1 u' Z3 G; M) B2 R/ L0 m2 V* L! ~# H
' b$ f$ V3 C- ~3 X. }
即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
- U t* A1 V7 h4 O5 c; E3 ]" q) s G: |" c
四、选择进入kde或者gnome,并自动启动X window应用程序 ' q' e6 m% G' i# I. i1 o
( b3 F6 q8 s* S( h如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 3 O+ h% R5 N$ Z6 u0 j4 e
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
# i6 z: y8 z& s, f$ |4 v' Z2 K7 Y, @& B! ^
?8 R& \' w2 M5 W" i+ D% I
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|