- 在线时间
- 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)
) x; ]8 P) @1 |: P) \9 S' F _0 g) u* b F ` W
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
+ F+ s. Y4 a: w* }, T. ]: ^" K: s一、linux启动的最后阶段的工作
8 X2 Y7 y5 d8 H/ z( q
. f& f: d$ _% ?1 J- Q3 W* Glinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
+ b8 ?2 o$ ?5 x, u, y" p1 v
1 b5 C6 L2 U- R8 M) k4 Q" H/ y, o; x运行xdm启动X window;
8 R7 j A8 ^) ]% y2 N4 n; }6 m4 I运行gdm,进入gnome桌面环境;
{) O+ b' T, V- O V6 b6 ~6 P运行kdm进入kde桌面环境;
, o) z- Y) X& x自动登录进入linux; 3 H- ~0 R; I! q; |4 F4 G W/ M" @
prefdm脚本框架大致如下: 5 T a+ B0 C2 Q" X: v
" J0 m0 h& M4 {& b( l) V5 X
#!/bin/sh ' L- I4 z0 w; z
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin ! M5 S$ l/ ?7 o, M- j3 @
. /etc/profile.d/lang.sh 8 U" R8 I6 Y% S( R6 z
# 第一步:查看是否为自动登录 * C: |; a3 Z4 f+ T/ q: `
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
" z6 D* w n0 C* Dif /usr/sbin/autologin; then ! F% k: U' q7 Z6 r2 L
exit 0
2 L8 B9 e' c d( ?& C( Pfi
Z9 N( c" \* }7 Y* x1 w. g8 {* ifi & [% l1 a8 S3 w- f, _
) D2 k1 j4 t9 P9 P/ D0 C# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式 - a" g2 K7 f4 }5 y
......
" m: @6 B! ? |* P& G0 r" q: f, \% B2 Q# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 5 w# ^9 t5 ]- z- c# V% S5 p
......
# ]" G4 a4 s, l% b
. r e2 h) J# B0 J& A5 H* \ 0 y+ Z% k+ P6 k. W, _& d5 \5 Y
! r7 p7 I0 Q# E# k2 f1 [. _0 J
% Y# w" } C' A
二、自动登录的实现(autologin的实现) : Y# h' r* |& B$ C' J# ?( ~
8 u+ n1 N2 J/ A0 ]4 K( M- I在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 * {6 _/ I$ u0 f
* I( z7 T" M" L3 T0 V {8 `" |
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。
( w$ n+ P8 r: a) K( j% M" s5 [! D8 w* v0 N: o/ U. a" X
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。 5 g7 v9 t3 _* u5 t
实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 & p0 V* Z8 h$ a( b' d0 T& o
startx脚本的最基本框架是:
6 A4 F/ M+ Y+ a. p: f! w' Q q% n2 k0 I* k2 s
a、 寻找.xinitrc,如果没有则使用xinitrc;
, B' J( F# r- [2 ]3 @5 z( L+ ^b、 寻找.xserverrc,如果没有则使用xserverrc;
`9 R2 P. u, t4 f& Xc、 根据找到的脚本确定xinit的参数; 3 X2 ?) Z! F0 I! \$ {' g
# d i+ Y8 U/ k0 [- E由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录:
; p! S0 n0 V( u
5 N/ \% h, a- m3 J/ |* I9 f
# V% N: X3 j7 ^4 W#!/bin/sh 9 ]1 u- @* x9 O$ R, a7 N
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
% w4 `! l2 m! X. /etc/profile.d/lang.sh
" `: U9 i4 U. D# 第一步:查看是否为自动登录
! e S4 [, ^( U8 e#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
3 t$ L: x+ K' x5 b, C% j( y#注释掉上边的条件测试,直接运行startx
4 Z9 p; @2 z7 T5 x8 |) [, eif /usr/X11R6/bin/startx; then
S9 n/ u# X7 J5 ?: mexit 0
3 i+ |( \9 ], W4 D# r! p2 nfi
+ |# b+ J6 o" d! A: M* `6 Q#fi - Q1 J6 D' a% Y& s9 o+ [+ R
. J% o* W9 n5 p1 w2 S4 G
# w( n* l2 n4 [7 `9 u \
7 Q" x c- { O. _2 f
: Q/ K) a2 ] k0 h当然,应确保/etc/inittab中的启动级别为5。
! g9 n9 J- y5 a+ f, I' |2 r: h& J* D# z2 `( s
重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。 * T4 [2 W6 |, o g3 |7 I% Z% k7 k
( }# s. c3 E8 V7 p) i
三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。
8 r# @& V- h7 _0 O# i0 k, J Q$ o$ |6 O
观察原来/etc/X11/prefdm脚本的自动登录部分:
9 Z( x8 ~6 u/ X; U8 i
! r& V" @' {/ \( ]" I5 Z" e+ G& e$ L: `& ]( e8 V
......
. k1 o0 y+ b) Z2 {0 y5 ^# 第一步:查看是否为自动登录
; m6 d/ n8 F4 _# Iif [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 7 N- w% f+ I3 Q9 r3 B7 U# X- ~
if /usr/sbin/autologin; then
/ i# {' E1 [; {3 Sexit 0
3 e# _ ?7 J" V; i6 `* P jfi
3 x: k5 x9 w/ Mfi
+ X- _% c3 @2 V2 O......
; E0 o+ M: Q# f" B& ]7 k- T; G) ^$ ?8 W& z
8 f% E4 f- Y& u+ Y5 i
, [3 S. m. _- h
! \7 D" |1 \5 N+ n$ k) f4 X不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。 7 ~0 P; i ?# O3 S. x
$ ~7 n6 {4 E; u1、/etc/sysconfig/autologin配置文件的实现: " J5 O* W: n/ I5 h* [3 Y- V
$ o( J* P) x( V# r. c7 t9 Q/ y
t, ~0 m$ U8 @1 ^' B5 a+ W! ~3 H8 {, J#config for autologin
# @) R# z* W$ d+ A4 eUSER=root % J, e, F6 ^# Z+ s: a' Q- ^
EXEC=/usr/X11R6/bin/startx
9 S/ y. v# {/ |+ D& N3 y说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 ( g; B7 R# ]: y& _2 b4 \: N0 R' b1 X
! d8 f/ m4 m/ z( K' n; Z$ ^
2 e8 f- s1 d; D* N
3 s* w5 d1 _2 D; `" o
- y( ^8 T) @% L# L3 U2、/usr/sbin/autologin可执行文件的实现:
2 _/ i" I! F$ [$ f, I
7 P4 h+ O5 X: W4 `3 m6 i- N- ]% f; E/ w
/*********************
; k- R' A5 t) {0 `" O L; E**** autologin.c ****
+ w0 A+ O4 M: V! U; [4 f*********************/
3 p7 k4 k. _) }% V7 Y! u$ l#include <stdio.h>
$ a$ Z% b' I0 g6 G#include <unistd.h>
% M# F T) i6 h; F" a# m" e2 a#include <string.h> 7 h4 j4 R& I0 t" b8 f' l
#include <errno.h>
! N- V. R, X1 @0 R" [7 i#include <sys/types.h> , x$ N# Q( K7 E8 V
#include <sys/stat.h>
V! d3 m! X0 w# X#include <pwd.h>
# y6 r% Q. }- T5 ]/ `3 e; D( k& \* n
int main(int argc, char **argv)
+ D6 a/ G* F( D" y6 X/ v' ^, d" T% r{
9 ]8 @ k0 ?+ ?+ Bstruct stat st;
; V) g5 S: ], IFILE *f;
, [% W$ _* A3 L3 N7 }8 Ochar *cfg;
& ~9 G3 B5 @2 h; ?; c7 Q1 Sstruct passwd *pw; " U) z- V5 j: H ?8 {9 B9 E
uid_t uid; : X3 q: G% B9 t7 X2 X+ y
gid_t gid; : C- p# B6 o4 M5 A9 F( T
char *dir, *shell; 9 I8 v9 Q; p, M8 I2 O
char *user=NULL;
$ r# E2 F- u: b" F u4 Wchar *cmd=NULL; + _' U- \! Q* |
( F, M. k6 A. l* w
user="root"; , s7 {5 Y" U! _& ]/ C
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, $ y: D% Q) ^' ]1 y8 |! Y
登陆用户名应该从/etc/sysconfig/autologin中得到, - h# K3 r% t$ Y$ A" K, v
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
; M! M" h U- a9 t: ~) a3 Scmd="/usr/X11R6/bin/startx";
, m: r- x0 b6 Z6 {- g' F/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/
6 B" k; Y# O: T
! F C4 [. |% ?5 b3 Rpw = getpwnam(user); 0 l8 m+ b0 z" b3 Z+ v
//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
4 m ?5 |7 \) w* }4 Y/ |( ^if(pw) { ) n1 f d. v2 A# `. ?0 j1 p% S
uid=pw->pw_uid;
( n1 o9 B4 H8 B7 i3 r0 Q Xgid=pw->pw_gid; dir=strdup(pw->pw_dir);
4 m) o- e& V6 T6 Ishell=strdup(pw->pw_shell); / y' o0 p2 U& B, Q% H. Z
} 7 m' n& j- ]' U5 G. i' `4 W
//获得用户相关信息
( y! M- H; j- _/ d* E* d7 |! Y, S; e2 o else { 7 M5 ?; r! ]- j6 q8 {9 n
printf("ERROR: No such user %s!\n", user);
% E$ ]$ z. |7 R9 C2 E! n) z2 _6 Y8 ^return 1; 7 [+ b5 x8 m0 S6 @/ v/ ?
} # }5 [; ^; ^2 ~# i
' ~; u N9 q; x* a7 B9 u
chown("/dev/console", uid, gid);
# }/ d! w0 T. r8 `chown("/dev/tty", uid, gid); 5 H* `; h. A$ j8 R( `4 s
//为控制台和终端设置用户ID及组ID ! |8 r, x/ Y+ X1 E
, b4 e) v& z6 U+ G7 z2 @//下面是设置用户相关ID % Q: R8 L! p' q" M9 v# y; @6 o6 z
setregid(gid, gid);
& x& T, P2 W) t: \ psetegid(gid);
" t& f6 m' t1 N" f- z psetgid(gid);
3 S7 c# u3 ?, c* k- d2 a4 wsetreuid(uid, uid); % P! W; O2 H* M- h2 M
seteuid(uid);
/ i9 M5 W/ }% c' Msetuid(uid);
, N) B6 f% Y" c I) L
$ b: _& l; H4 I: |3 Osetenv("HOME", dir, 1);
( T0 s9 f& {) t gsetenv("SHELL", shell, 1);
" ?2 k% O0 |0 ?, f2 p: |setenv("USER", user, 1); ' q: a( c% ~) u, F
setenv("LOGNAME", user, 1);
0 }) Q" X- I- s//设置用户相关环境变量
* \' [. H# ^( r& c: ^: j* N5 d( S8 W8 C! p. c; k# S* r8 L5 M& m& S
chdir(dir); 7 e7 L" H0 C8 ?& A. v
//切换到用户根目录 ) }' [ j* y* J9 j2 B0 Y/ ?5 P( ?
user=NULL;
& u! s) ?5 u0 F: u% X8 Q- w9 d' g8 W, L: `
execvp(cmd, argv); O7 w; P A) W
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ / y9 T( D- S/ W1 [
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); 8 ]+ F3 `4 E( ^, H- E* x
return 2;
+ Y, k: E# _( E1 b} 5 j0 S, q' u6 a }
% ?9 d% a) q3 _7 c0 }0 X
4 z5 Z8 K$ _. E. l, C& ~3 z e
5 i" `/ t* o8 ]5 h8 n5 t; c f
* i/ f- A6 }$ v& a运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
+ g/ a+ }' x p' W- p7 K3 d
* _' p% m) ~! \- l! K' O0 R/ g, J如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: 7 r; l/ W; o9 R3 U" s
9 I) Z$ \/ u+ N1 D0 Q# y9 I- w5 {
8 I, d. ?2 B7 Q! y- {
......
W; J; O$ o0 j: f! q# 第一步:查看是否为自动登录
' o; ?3 U5 V s7 [/ sif /usr/sbin/autologin; then
/ d1 \& z4 S# e# cexit 0 $ m+ }+ \- P5 Y8 K4 S4 P
fi
4 v, F2 Q7 Y( L- i! a! X3 @//第二步 ......
+ _+ P( j9 M3 R* y8 s+ T......
5 H" n/ ]: w! ^6 r* p- F& y5 B
7 d9 G5 Q9 O" [& o% V4 D- E6 e' Q & M! m# \; H0 ?) r7 P
7 A1 m4 B# C9 d3 t: N s1 K( V4 v
- T3 u0 e* U; a# w即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
$ e! r1 l$ l1 j6 q8 T7 Z4 k4 n! T, j% M- U6 v
四、选择进入kde或者gnome,并自动启动X window应用程序 $ E& N5 r, m4 u
: \5 ^; f1 A2 b2 s0 l如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 7 n, o; ]; h* O4 g
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 0 f3 `& [5 l- E- e3 q: A# s
2 T+ G4 `7 n4 ^9 ]; c5 {9 j- I
, N; D4 I) W' c1 Qhttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|