Ubuntu快速安装 LAMP

以前在Ubuntu下安装lamp可以采用新立得软件包管理器来安装,方法如下:

System–>Administration–>Synaptic
Package Manager–>Edit–>Mark packages
by Task–>LAMP Server–>OK

如果是中文节面则是系统--》系统管理--》新立得软件包管理器-》编辑--》使用任务标记分组软件包--》LAMP Server
(勾选)--》返回到上一个窗口,点击应用,这个时候系会自动下载安装lamp环境软件包,很快就会完成,而且系统每次升级还会升级lamp环境到最新版
本。 【LINUX公社 www.LinuxIDC.com 】

但把Ubuntu重新安装为最新版本Ubuntu
10.10后,在新立得软件包管理器里并没有立得软件包管理器-编辑--使用任务标记分组软件包--

怎么办?

实际上只需2条命令即可

sudo apt-get install tasksel

任务标记分组

sudo tasksel install lamp-server

安装途中MySQL要求设定账户有密码,这是与操作系统没关系的账户与密码。

会碰到如下问题:

[email protected]:/home# sudo tasksel install lamp-server
Can’t call method “set” on an undefined value at
/usr/share/perl5/Debconf/FrontEnd.pm line 126,
<GEN0> line 5.
Use of uninitialized value $ret in scalar chomp at
/usr/share/perl5/Debconf/Client/ConfModule.pm line 132,
<STDIN> line 4.
Use of uninitialized value $ret in split at
/usr/share/perl5/Debconf/Client/ConfModule.pm line 133,
<STDIN> line 4.
Use of uninitialized value $ret[0] in string eq at
/usr/share/perl5/Debconf/Client/ConfModule.pm line 134,
<STDIN> line 4.
Use of uninitialized value $ret[0] in string eq at
/usr/bin/debconf-apt-progress line 350,
<STDIN> line 4.
tasksel: aptitude failed (9)

参考:http://ubuntuforums.org/showthread.php?t=1660308

As far as I know, tasksel has been dropped from the default
packages due to a problem with it uninstalling /everything/ when
told to remove package groups (e.g. lamp-server).

Instead, you should use apt-get. The package groups still exist,
but you need to call them with a caret (^).

e.g.

Code:

[转载]ubuntu下vsftpd配置详细篇

的确挺麻烦的,还是算了

原文地址:ubuntu下vsftpd配置详细篇作者:好人

也难怪linux难以像wnidows那样普及,其下面的很多应用软件实在是太费周折了,曾经以为开源的linux纯朴明晰,命令行的操作形式高效无比,现在自己不断重复繁琐的配置命令、不断应对各种各样稀奇古怪的问题的时候偶然回想windows下桌面软件鼠标轻点轻松搞定的惬意,让人不禁难以取舍。就像黑莓手机对于我一样,清新亮丽的系统任何光照下都永远清晰的屏幕对之单调过时的应用软件,同样让人迷茫。

言归正传,本文说是教程,其实就是我在ubuntu
9.10下配置ftp服务器的实际过程,本文并无高深之处,只是实现了我们所需的ftp服务器,因此本文适合初次接触ubuntu9.10下vsftpd
配置的朋友,或者配置中遇到与我同样问题的朋友,高手们就别看了,各回各家,各找各妈,该干嘛干嘛去吧。

1、 本人配置的ftp服务器的设计要求如下:
(1)、匿名用户可登录浏览,但不能下载
(2)、设置4个不同等级的用户使用此ftp服务器(虚拟用户),分别如下
用户名:nan306  
路径/home/vsftpd        
管理用户,可对ftp服务器的所有文件进行任何操作
用户名:down    
路径/home/vsftpd/down   
下载用户,只可下载此目录下的文件
用户名:upload  
路径/home/vstfpd/upload  上传用户,在此目录下可上传下载删除等操作
用户名:wsn     
路径/home/vsftpd/wsn    
实验室文件管理目录,此用户目录为本实验室内部资料,其下挂在down虚拟路径

2、vsftpd的安装
$ sudo apt-get install vsftpd
安装完后不用做任何配置既可用匿名方式进行访问,默认的ftp文件夹为/srv/ftp
3、vsftpd的开始、关闭和重启
$sudo /etc/init.d/vsftpd start  
#开始
$sudo /etc/init.d/vsftpd
stop   
#关闭
$sudo /etc/init.d/vsftpd
restart   #重启

关于vsftpd的开机自启动,当vsftpd装好后是默认开机自启动的,如果不需要可关闭,关闭方法很多,网上自己看吧,我用一条命令

$sudo mv /etc/rc2.d/S20vsftpd /etc/rc2.d/K20vsftpd
具体请参考开机自启动文章
http://hi.baidu.com/jidaxiaobeibei/blog/item/e16309446cc0b237879473d6.html

3、vsftpd的配置
这一块网上信息是铺天盖地,关于配置参数我这里就不一一列举,初次接触的朋友参考http://os.51cto.com/art/201003
/189123.htm这个网址,高级点的配置参考http://www.517sou.net
/blogview.asp?logID=515#commmark_241。如果没接触国建议先看看第一个网址里面的内容,简单明了。

关于配置这块初次配置ftp的朋友我的建议是别一下把所有配置全看完就照着做,这样都配完了ftp出了问题都不知道哪步错的,一步步来,配一步测试一步。

我的配置过程如下:
vsftpd的配置很简单,就是打开/etc/vsftpd.conf文件,
$sudo vi
/etc/vsftpd.conf      
#我这里用ssh登录服务器配置的,所以用vi,本机的话可以直接  sudo gedit
/etc/vsftpd.conf
然后对参数进行修改,修改完咧就重启服务器
$sudo /etc/init.d/vsftpd
restart   #重启就可以实现配置功能。

关于配置文件修改一定注意一下几点:
1、配置前最好把配置文件备份一下, sudo cp /etc/vsftpd.conf
/etc/vsftpd.conf.back,以备配错了恢复
2、所有配置语句后面不要有空行,我自己的配置很严格连空格都没有,把所有没必要的注释尤其是汉语注释全删除,如果配置语句后面或前面有空行或空格会报错

3、为了防止出现第2点中的错误,请尽量无比自己一条条改写配置语句,不要从网上拷贝,很容易多空格,多回车
4、不清楚自己是否需要的请保持配置文件原样。

对本人配置的服务器中 vsftpd.conf的参数使用如下:
listen=YES            
#启用独立vsftpd服务器
#listen_ipv6=YES      
不需要,注释掉
anonymous_enable=YES  
#本服务器需要匿名访问
local_enable=YES      
#要用虚拟用户,需要本地访问的(关于本地用户和虚拟用户不要迷茫,稍后解释)
write_enable=YES      
#需要本地用户对文件进行修改和删除
#local_umask=022   
 FTP上传文件权限
,默认是077,本服务器每个虚拟用户都有上传权限设置,总的就留空注释掉了
#anon_upload_enable=YES 是否允许匿名用户上传,不需要匿名上传注释掉
#anon_mkdir_write_enable=YES 是否允许匿名用户的写和创建目录的权限,不要匿名管理,注释掉
dirmessage_enable=YES 当切换目录时,是否显示该目录下message隐藏文件的内容,这个用来显示登录信息的
设为YES
message_file=Welcome    
显示的欢迎信息,在ftp目录下建Welcome的文件,里面写上登录信息即可,一般人常用.message隐藏文件
xferlog_enable=YES 是否激活上传和下载的日志,需要
connect_from_port_20=YES 是否启动FTP数据端口20的连接请求 
需要
chown_uploads=YES 是否改变上传文件的所有者,我这里需要改变上传文件所有者
chown_username=virtual
改变上传文件的所有着为virtual,这个virtual用户一会要新建的,用来实现虚拟用户登录
xferlog_file=/var/log/vsftpd.log 上传/下载日志文件所默认的路径
xferlog_std_format=YES 是否使用标准的ftpd xferlog日志格式
idle_session_timeout=600 是否将在用户会话空闲10分钟后被中断
data_connection_timeout=120 是否将在数据连接空闲2分钟后被中断
#nopriv_user=ftpsecure
是否运行vsftpd需要的非特殊系统用户默认nobody  不需要
#async_abor_enable=YES
是否是否允许运行特殊的FTP命令async   不要
ascii_upload_enable=YES
是否启用上传的ascii传输方式   需要
ascii_download_enable=YES
是否启用下载的ascii传输方式   需要
ftpd_banner=Welcome to blah FTP service.
用户连接服务器后显示信息,显示信息可以随便写
#deny_email_enable=YES 是否允许某些匿名用户使用邮件地址(默认的)
max_clients=10 #FTP服务器最大承载用户,本人设为10
max_per_ip=5 #限制每个IP的进程
local_max_rate=256000 #最大传输速率(b/s)
#hide_ids=YES #是否隐藏文件的所有者和组信息,不隐藏
下面是用来虚拟用户登录的
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
guest_enable=YES            
使用虚拟用户
guest_username=virtual      
将虚拟用户等同本地用户 virtual
user_config_dir=/etc/vsftpd/vsftpd_user_conf  
虚拟用户配置文件夹
pam_service_name=vsftpd.vu   
虚拟用户加密设置
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

其他未列出来的视情况自己斟酌,如不明白清保持原样。

配置完了请重启ftp,看是否报错,是否可以连接,如报错或不能连接请自己检查配置文件,如果还不能启动,报错,很有可能是配置文件有空格或回车,检查并修改。如果实在还不行,恢复配置文件,重新一条条验证配置。

4、使用虚拟用户登录(文本法)
此实现有很多方法,主要的是文本法和数据库法,其实大同小异,本文使用文本法。
此处涉及到两个概念,一个是本地用户,一个是虚拟用户。
本地用户就是linux实实在在的一个用户,如root,你的登录用户等等都是本地用户。
虚拟用户不是linux上的用户,只是自己起的虚拟用户,用来使用ftp的,虚拟用户必须关联到一个本地用户上。
虚拟用户的实现可以参考官方http://wiki.ubuntu.org.cn/Vsftpd虚拟用户设置,但是里面有错误,请注意甄别。官方的都错,没天理呀,我就是因为这个错误搞了好久,错误很简单,就是其中“为虚拟用户创建本地系统用户
”那块本地系统用户建立错了,应该是virtual,既改为:
sudo useradd virtual -d /home/vsftpd -s /bin/false
sudo chown virtual:virutal /home/vsftpd
当然这个用户名字你也可以改,但是此处的名字必须和配置文件vsftpd.conf中guest_username=virtual项的参数相同。

………………………………………………………………………………………………
下面是我的配置过程,结合官方的那个网址看啊,大部分相同,略有不同:
首先先新建文件夹
sudo mkdir /home/vsftpd
cd /home/vsftpd
sudo mkdir down upload wsn
(1)、创建虚拟用户数据库
新建loguser.txt文件,
$sudo vi /home/loguser.txt
里面输入虚拟用户名和密码,格式如下
nan306
mima1
wsn
mima2
upload
mima3
down
mima4
注意不要多空格和空行,其中nan306,upload等为虚拟用户名,另外两行为相应密码
生成数据库
先装一个软件
$sudo apt-get install db4.7-util
新建一个文件夹,放置配置文件
sudo mkdir /etc/vsftpd
然后执行
$sudo db4.7_load -T -t hash -f /home/loguser.txt
/etc/vsftpd/vsftpd_login.db
最后设置一下数据库文件的访问权限
$sudo chmod 600 /etc/vsftpd/vsftpd_login.db
配置PAM文件
新建/etc/pam.d/vsftpd.vu
$sudo vi /etc/pam.d/vsftpd.vu
输入内容如下:
auth required /lib/security/pam_userdb.so
db=/etc/vsftpd/vsftpd_login
account required /lib/security/pam_userdb.so
db=/etc/vsftpd/vsftpd_login
* 我们上一步建立的数据库 vsftpd_login 在此处被使用
* 我们建立的虚拟用户将采用PAM进行验证,这是通过/etc/vsftpd.conf文件中的
语句pam_service_name=vsftpd.vu来启用的,稍后你将发现。
(2)、为虚拟用户建立本地用户
新建一个系统用户vsftpd,用户家目录为/home/vsftpd,
用户登录终端设为/bin/false(即使之不能登录系统)
sudo useradd virtual -d /home/vsftpd -s /bin/false
sudo chown virtual:virutal /home/vsftpd
现在为止,我们的3个用户都可以工作了,可是它们的根目录现在都是/home/vsftpd,权限也都一样。
那么怎么才能完成我们预定的目标呢?
(3)新建etc/vsftpd_user_conf文件夹
在上面的配置中,有这么一行 
r_config_dir=/etc/vsftpd/vsftpd_user_conf
现在,我们要把各个用户的配置文件放到目录/etc/vsftpd/vsftpd_user_conf中
sudo mkdir /etc/vsftpd/vsftpd_user_conf
cd /etc/vsftpd/vsftpd_user_conf
sudo touch nan306 wsn upload down

每个文件既为一个配置文件,如nan306是个系统管理用户,里面配置如下:
打开nan306
sudo vi /etc/vsftpd/vsftpd_user_conf/nan306
里面添加
write_enable=YES
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
local_root=/home/vsftpd
这里要注意不能有空格,不然登录的时候会提示出错。下同

wsn用了管理wsn文件夹,配置如下:
打开wsn
sudo vi /etc/vsftpd/vsftpd_user_conf/wsn
里面添加
write_enable=YES
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
local_root=/home/vsftpd/wsn
wsn目录下面还要挂载down文件夹的虚拟路径
在wsn目录下新建目录down
sudo mkdir /home/vsftpd/wsn/down
然后系统启动是将/home/vsftpd/down挂载到/home/vsftpd/wsn/down
改写/etc/rc.local实现开机启动
sudo vi /etc/rc.local
添加    mount
–bind /home/vsftpd/down /home/vsftpd/wsn/down

upload目录中
write_enable=YES
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
local_root=/home/vsftpd/upload
down目录中
local_root=/home/vsftpd/upload

至此配置完了。重启vsftpd我们就可以看到效果了^_^
/etc/init.d/vsftpd restart

500 OOPS: cannot change directory:

linux打开ftp遇到的问题 500 OOPS: cannot change
directory:

google好多都是 执行这个就OK setsebool
ftpd_disable_trans 1 service vsftpd restart

但是执行的时候遇到这个问题  Could
not change active booleans: Invalid boolean

搜了好久终于解决

setsebool -P ftp_home_dir=1

参考文献:

最初级简单的请看下面两个

http://os.51cto.com/art/201003/189123.htm

http://os.51cto.com/art/200901/106622.htm

高级点的看下面两个
http://www.linuxsir.org/main/?q=node/152#8.4       
这个很好的,里面有很多实用设置
http://www.517sou.net/blogview.asp?logID=515#commmark_241   
这个很全很全,非常全,非常推进

虚拟用户官方配置,有错误,记得更改

http://wiki.ubuntu.org.cn/Vsftpd虚拟用户设置

tomcat安装为服务service.bat设置,启动服务时出错,提示“…特定代码0”

将JDK中BIN文件夹下的 msvcr71.dll 这个文件复制到 TOMCAT 中的 BIN 下

Android中包含多个Activity的应用退出按钮实现

Android中application 全局变量

android
编程中,application这样的名词似乎变得那样的不常见,而让大家更为熟悉的是activity、intent、
provider、broadcast和service。但其实android中的application也有着它自身的用处。打开manifest文
件,会看到有一个application配置标签,这就是有关application的使用了。

就是说application是用来保存全局变量的,并且是在package创建的时候就跟着存在了。所以当我们需要创建全局变量的时候,不需要再像j2se那样需要创建public权限的static变量,而直接在application中去实现。只需要调用Context的getApplicationContext
或者Activity的getApplication
方法来获得一个application对象,再做出相应的处理。

退出按钮实现

首先,创建Application来存储所有打开的Activity的list。代码如下:

package com.deaboway.view;  
import java.util.ArrayList;  
import java.util.List;  
import android.app.Activity;  
import android.app.Application;  
public class Deaboway extends Application  

    private List<Activity> mainActivity = new ArrayList<Activity>();  

    public List<Activity> MainActivity()  

        return mainActivity;  

     

    public void addActivity(Activity act)  

        mainActivity.add(act);  

     

    public void finishAll()  

        for (Activity act mainActivity)  

            if (!act.isFinishing())  

                act.finish();  

             

         

        mainActivity = null 

     

}

其次,在所有Activity的  
@Override   
public void onCreate(Bundle savedInstanceState) {}方法中加上:

      public void onCreate(Bundle savedInstanceState)  

          super.onCreate(savedInstanceState);  

    Deaboway appState = (Deaboway)this.getApplication();  

    appState.addActivity(this);  

          setContentView(R.layout.main);  

         。。。。。。。  

      } 

 

第三,在退出按钮的地方调用:

    OnClickListener()  

                public void onClick(View v)  

                    Deaboway appState = (Deaboway)getApplicationContext();  

                    appState.finishAll();  

                 

            

 

最后,要记得在manifest中的application标签中添加 android:name=”.Deaboway”