- 在线时间
- 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)
0 v; v0 y8 l% W0 H; S' }; ~$ g( K/ W
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
0 O2 a: A# d8 Q3 ?) C) T6 L$ d8 M一、linux启动的最后阶段的工作
3 B1 v- w' T% w% ]; X. ~, h
: a9 h1 \6 `# o* @3 S# glinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
7 U* h# H8 Q& H( g' Q' M: c1 r8 B+ o! l( a. J6 Y. i$ q
运行xdm启动X window;
) I; S2 v4 i( y3 N9 r$ L运行gdm,进入gnome桌面环境; 6 N; g! `: v1 S: p) r( {
运行kdm进入kde桌面环境;
U3 z: s+ J) S) G" G8 c# a8 V0 e自动登录进入linux;
& W! F" }) P! Q7 h3 J( E3 X5 A' iprefdm脚本框架大致如下: : A( w+ f& ^6 B/ z9 X: r2 N
* m4 a a& H4 {/ }7 R3 F+ a$ ~
#!/bin/sh ' C! v3 m+ W8 |- n& x1 `
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
6 X& F+ y1 s1 [" t2 Y. /etc/profile.d/lang.sh
- l0 U3 V# q g y' l! B9 x# 第一步:查看是否为自动登录
6 w3 [; I$ q6 i! s2 f- j; a/ }if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then $ }4 u5 c; a2 {4 @
if /usr/sbin/autologin; then 7 `* y! y' R, J
exit 0 ( Y& `/ a* ]$ P4 Q- E4 |. w
fi
: D5 Z& z( _3 Q& u, }- W6 hfi
' O) }. f4 ]0 ^$ ^+ g
" U' N' `! x8 m# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 + F% e, ^+ i1 n% X2 m! E' m2 T
...... 3 w) l0 [! u: E* [
# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 1 K6 w$ s+ g1 e1 k- s2 m7 ^* }
......
% |8 c) S H" Y: `$ K4 B, ?) i, q4 ?/ M& [2 P9 p7 D4 i0 \
% S2 H1 ^: e7 R5 E; b' A
3 i, q! w8 S6 w4 u, z
7 B. F0 I9 ?5 B' W二、自动登录的实现(autologin的实现)
2 B6 E( g$ q1 |3 J' X* t# `
W5 C# H Z* _7 h, _5 H在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
- i; G, g0 f) {9 R5 U
7 H$ u) I" _! a0 H自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 a2 k' W6 |* Z0 |
( J6 f! m1 Z1 Z' i4 ~$ D3 d2 P) GXinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 0 {4 S! f) `( N2 |2 {. s9 L
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 1 x! T! L& [1 w% L- h
startx脚本的最基本框架是:
5 F+ d8 C/ c8 H6 T1 f8 i' h+ C, E! R+ q# Z
a、 寻找.xinitrc,如果没有则使用xinitrc; ) \: s( ]! i% Z& A: e2 i: h/ X" Y
b、 寻找.xserverrc,如果没有则使用xserverrc; % ]; E) i0 x R6 n8 F% z
c、 根据找到的脚本确定xinit的参数;
- S' [, v. ^) F& N/ m8 w
4 ~# \; S# T! J* v+ B& q8 U+ x8 E; m由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: - e5 U+ Z. w9 ~0 ]; s
9 M8 k; m; i3 U3 I2 r5 {/ A: U( ^; T: P; ?
#!/bin/sh
! e# Q$ U5 {! L' yPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin , N/ V7 }: H3 o, W! J$ D" Q
. /etc/profile.d/lang.sh 4 ]( B/ d+ I. r& v. t/ n
# 第一步:查看是否为自动登录
' D6 b% D$ g5 g1 P8 p( _9 q' P#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 5 P9 g* N7 S. S) n4 c! h+ Y
#注释掉上边的条件测试,直接运行startx 8 K0 p3 S& c+ R. C- \
if /usr/X11R6/bin/startx; then & S* A# ^- e% n+ e5 H4 p6 F
exit 0
4 a# W& ^0 B# j* Z" z3 N! w4 ~% {fi 6 D9 H* b7 z7 R
#fi 8 f6 G& ?* Y7 b5 k' ?
3 w3 r9 l2 q, U$ i! j
) X: ?& L9 B0 h! E1 x: I$ P9 b- H/ x) H) U8 V' g4 K2 v
/ K. Z1 M; a) ^$ ?6 u! d I; P4 Z
当然,应确保/etc/inittab中的启动级别为5。 / z0 s. J y) D: {
2 U# T0 Y. B: I' @" k5 C% a重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
: {7 O! V) i) v3 d3 f8 L2 s: c: G# v [( ^
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
, c; \1 ]& [: C& \8 h7 O3 k; \/ u
+ o3 X2 y1 K5 k6 \, o观察原来/etc/X11/prefdm脚本的自动登录部分: 5 r( \5 q" @8 ?3 t" p/ R3 V
, ?( V. m7 f! F" B( H
" F4 Z5 l5 G9 B! Z5 a) n
......
" g+ R2 S9 X* q% ?/ f O9 g$ }% i# 第一步:查看是否为自动登录
) w; e4 M2 D0 g6 wif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 3 h0 | U9 Z+ U b
if /usr/sbin/autologin; then
/ @2 H0 o- o% ^! qexit 0 s& x5 i% Q8 {! @ X6 L/ V6 H: d
fi : e/ {8 m& _* f2 K& v& X% r
fi
5 ^1 x0 i9 n% _* z3 G......
( _% I9 U8 z/ [6 @: i! Y0 n) p1 B* K8 M7 h1 C0 p! e# [$ N( b8 z
3 x2 i7 }; Y9 ], ~9 F5 V7 n9 U3 t6 o7 b3 _; x E5 @$ b
7 [8 c" Y1 r5 ~+ k$ b6 z, C不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
4 V) [6 d7 P6 i
: B. I9 p# {: v: I1、/etc/sysconfig/autologin配置文件的实现: % @: _8 y! r6 T9 z- l0 r% |
+ X3 `6 p# U0 h" q
2 x/ A! W+ B! T1 n3 g
#config for autologin 2 H$ ?3 {' E3 L5 \* m
USER=root
e3 M; }; [) `* m7 A3 i- S% pEXEC=/usr/X11R6/bin/startx
5 v# w4 Z; K! A) F6 U2 D( ?说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
9 A, O9 l8 a& k
' J3 f0 a. p ]- ` * G$ C) X- h7 u: T
! g! f Z2 _( d9 b$ i
0 M$ o8 |" I* X8 W3 r& L7 D7 q2、/usr/sbin/autologin可执行文件的实现: ' h; L; T7 v7 w) g8 x3 {2 [
- G8 ~/ v; Z* c+ Z# F) L
- S7 k: B# Z- M1 a/*********************
( a9 T/ X0 B* ~0 Y4 z0 ~**** autologin.c ****
& r* O+ @" q* G*********************/ 1 i# r& K0 B8 {8 w) S! u- H2 Q0 e' X
#include <stdio.h>
! j5 Q: N8 s9 l4 v- d$ ^0 r#include <unistd.h>
5 D# H; W# g% e' A#include <string.h> 3 S0 b" M( N. a8 f& a
#include <errno.h> ; U9 s& e& B$ p% N( V6 ^
#include <sys/types.h>
+ J$ N1 j& H7 d) \$ `% }" i#include <sys/stat.h>
" M7 y. t' Y: ]1 v& \#include <pwd.h> ! r% J7 J! Y8 q2 s' d
" g# Y- T% Z, m* r, ` f& u
int main(int argc, char **argv) " W- D, z7 Y5 L
{ 2 k# r! h9 q) p4 \ w
struct stat st; ) v; h; f) H2 e) T! M- L
FILE *f;
9 |' s5 a/ h1 Fchar *cfg;
) a! P4 p: S3 Z( L2 M7 _) Sstruct passwd *pw;
0 u$ |. n9 x, [uid_t uid;
`# x! p( S% @: x% O7 Mgid_t gid; / V( n. X# ^- q
char *dir, *shell; : Z& M; b6 i) B
char *user=NULL; 6 e, S% I: V& w$ \( ]. N: Q
char *cmd=NULL; ) y+ W( D+ M# Q& B
# Y( w, P% s+ zuser="root";
* t3 Z: ?/ O2 `* H# t& U/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 4 q7 m5 j. v& k; E2 J' a
登陆用户名应该从/etc/sysconfig/autologin中得到,
; t6 h+ Q& f W- R) z# X程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ , L, Q; V6 c# M" ~4 |4 e U4 b; i
cmd="/usr/X11R6/bin/startx"; 0 J: c+ X- T9 R( k
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ - a9 n9 ?7 q% E$ s* w; P2 B
' ]1 U- _# t+ y$ t6 [% ~7 c1 |. i
pw = getpwnam(user);
5 f+ e8 C" z1 }( E//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 2 b8 e% ?2 Y, g: V
if(pw) {
& H; o! y" g. [. m6 Puid=pw->pw_uid; : V. y5 E# A* @ B& M9 g; Y1 `
gid=pw->pw_gid; dir=strdup(pw->pw_dir);
^2 `# @6 \9 `4 s/ gshell=strdup(pw->pw_shell); 3 d5 c+ x x t/ s" F
} + V6 w$ j A7 f9 {6 \
//获得用户相关信息
5 O& d* b0 m7 s- W8 Z0 a8 V9 g else { . d! V2 A3 }8 K; ~# A
printf("ERROR: No such user %s!\n", user);
! ^( P4 \8 `7 j5 Oreturn 1; 6 p9 h8 N7 e: }7 v
}
: X& d! L h; O& k3 \; Q! U6 h( c p' F1 ]
chown("/dev/console", uid, gid); 2 s, A' @7 T6 D# w5 M
chown("/dev/tty", uid, gid);
4 M0 ]7 z5 A* J ?. {& R- ?1 U& V//为控制台和终端设置用户ID及组ID
( ~6 V) \9 i& f. v( w) x/ R* Z. O S
# G. Z5 m( ]2 o7 N) C//下面是设置用户相关ID
# ]' K" B! E* V4 j3 Esetregid(gid, gid);
1 q; E9 C8 y# t9 B( C) ysetegid(gid); $ y) D; }1 t2 C: y8 o" F5 D
setgid(gid);
1 p+ ?7 u/ O: S0 S/ U/ A1 Qsetreuid(uid, uid);
- D5 p+ k. ?( Y. x6 I7 b7 [# z5 zseteuid(uid); * J {2 v% }( G: R( F% A
setuid(uid); 5 O: {- R8 P' F0 L; s7 `
5 j" u4 ]3 }/ U- h9 [# {( H
setenv("HOME", dir, 1); 3 ]/ Z; x# t' \. c1 R. D
setenv("SHELL", shell, 1);
w f+ @' p- g! q! Jsetenv("USER", user, 1);
1 i3 H6 L- C: Hsetenv("LOGNAME", user, 1);
3 ~2 S+ R2 L% m. ]. E _( L//设置用户相关环境变量 ) i3 p8 E0 f$ P& S1 l L
9 O7 i5 x8 K+ Z8 ~chdir(dir);
" @7 E* g( `/ d; o Z//切换到用户根目录 1 F( I; e1 Z/ ]" P
user=NULL; 8 J' ]7 w" J, N% t5 m, Y
4 X" L- Y. ?8 ~7 jexecvp(cmd, argv);
( C( H( o V8 F9 |$ @4 F; s& P( T# t- `/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ " F2 d% J( b& U: V. R5 @
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
! D; u2 g4 Z" L4 t4 ^return 2; . J4 u+ C8 x" z8 o3 \5 r
}
( s8 Y; X* S% m
4 M0 G$ o0 z. J8 R7 Q
- z3 M0 U/ Z. ^$ o0 Y5 N. [. g: h. H. ? r2 R
s6 A8 y6 ]! z8 z4 P
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
7 K% N) Z: ?; J/ V. ]
; {5 s9 x- Z& ^) Q2 _如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 9 y$ D N- z3 [( M: T8 e5 U
- ^' s- N# t8 P; `7 s9 p( a( d% P0 d2 S9 S
...... $ s: v2 b) I* ]! Y: a1 n6 k
# 第一步:查看是否为自动登录 4 K {4 K, a' R V; r: U/ J; J& t
if /usr/sbin/autologin; then ! g, R" h* q- O2 V! T! F. ^
exit 0
. E3 d( {- f4 \fi
0 `/ t k O# k3 z//第二步 ......
$ X4 V) @( r1 b* P6 p...... % S5 A, b- [' U/ }
+ ^; ?- e! a7 K' ~7 ^: n7 g % B( u& b9 C! e$ d" j
9 P; c0 p' K4 _. K5 ^# E) p
) D6 V0 x3 P5 g即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。 - E( W6 N" l7 @/ ^1 D5 |- e
0 B) @' A5 U/ N2 H$ ^四、选择进入kde或者gnome,并自动启动X window应用程序
& r6 Z4 \2 ]; c- d( |& y5 ?3 i6 b
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。
0 ^2 @7 g( X" B/ o一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。
4 g# w6 c; q. X3 A- W2 y0 X( ]- o2 X- T# g
: O: V+ N2 f3 G3 `8 C- _+ E
http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|