nginx编译安装

nginx编译安装  
===========================================  
Nginx官网:http://nginx.org/  
Nginx官网下载地址(选择 Stable version 稳定版):http://nginx.org/en/download.html  
官网安装介绍:http://nginx.org/en/linux_packages.html  


一:安装  

1.1:环境准备  
    ~]# yum -y install gcc gcc-c++  pcre-devel  openssl-devel  

2.2:编译安装  
    ~]# tar -axf nginx-1.10.0.tar.gz  
    ~]# cd nginx-1.10.0/  
    ~]# useradd -r nginx  
    ~]# ./configure --prefix=/usr/local/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module --with-http_secure_link_module --with-http_stub_status_module --with-http_auth_request_module --with-threads --with-stream --with-stream_ssl_module --with-http_slice_module --with-file-aio --with-http_v2_module --with-ipv6  
    ~}# make && make install  


1.3:加入环境变量  
        ~]# vi /etc/profile.d/nginx.sh  
        export PATH=$PATH:/usr/local/nginx/sbin/  

        ~]# source /etc/profile.d/nginx.sh  


1.4:启动与重启停止  
        启动:nginx  
        重载:nginx -s reload  
        快速停止:nginx -s stop  
        有序退出:nginx -s quit  


1.5:加入系统服务与开机启动  

CentOS 6   
    ~]# vi /etc/rc.d/init.d/nginx  
    ~]# chmod +x /etc/rc.d/init.d/nginx  

--------------------------file start---------------------------------  
#!/bin/sh  
#  
# nginx - this script starts and stops the nginx daemon  
#  
# chkconfig:   - 85 15  
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \  
#               proxy and IMAP/POP3 proxy server  
# processname: nginx  

# Source function library.  
. /etc/rc.d/init.d/functions  

# Source networking configuration.  
. /etc/sysconfig/network  

# Check that networking is up.  
[ "$NETWORKING" = "no" ] && exit 0  

nginx="/usr/local/nginx/sbin/nginx"  
prog=$(basename $nginx)  

sysconfig="/etc/sysconfig/$prog"  
lockfile="/var/run/nginx.lock"  
pidfile="/var/run/${prog}.pid"  

NGINX_CONF_FILE="/etc/nginx/nginx.conf"  

[ -f $sysconfig ] && . $sysconfig  

start() {  
    [ -x $nginx ] || exit 5  
    [ -f $NGINX_CONF_FILE ] || exit 6  
    echo -n $"Starting $prog: "  
    daemon $nginx -c $NGINX_CONF_FILE  
    retval=$?  
    echo  
    [ $retval -eq 0 ] && touch $lockfile  
    return $retval  
}  

stop() {  
    echo -n $"Stopping $prog: "  
    killproc -p $pidfile $prog  
    retval=$?  
    echo  
    [ $retval -eq 0 ] && rm -f $lockfile  
    return $retval  
}  

restart() {  
    configtest_q || return 6  
    stop  
    start  
}  

reload() {  
    configtest_q || return 6  
    echo -n $"Reloading $prog: "  
    killproc -p $pidfile $prog -HUP  
    echo  
}  

configtest() {  
    $nginx -t -c $NGINX_CONF_FILE  
}  

configtest_q() {  
    $nginx -t -q -c $NGINX_CONF_FILE  
}  

rh_status() {  
    status $prog  
}  

rh_status_q() {  
    rh_status >/dev/null 2>&1  
}  

# Upgrade the binary with no downtime.  
upgrade() {  
    local oldbin_pidfile="${pidfile}.oldbin"  

    configtest_q || return 6  
    echo -n $"Upgrading $prog: "  
    killproc -p $pidfile $prog -USR2  
    retval=$?  
    sleep 1  
    if [[ -f ${oldbin_pidfile} && -f ${pidfile} ]];  then  
        killproc -p $oldbin_pidfile $prog -QUIT  
        success $"$prog online upgrade"  
        echo   
        return 0  
    else  
        failure $"$prog online upgrade"  
        echo  
        return 1  
    fi  
}  

# Tell nginx to reopen logs  
reopen_logs() {  
    configtest_q || return 6  
    echo -n $"Reopening $prog logs: "  
    killproc -p $pidfile $prog -USR1  
    retval=$?  
    echo  
    return $retval  
}  

case "$1" in  
    start)  
        rh_status_q && exit 0  
        $1  
        ;;  
    stop)  
        rh_status_q || exit 0  
        $1  
        ;;  
    restart|configtest|reopen_logs)  
        $1  
        ;;  
    force-reload|upgrade)   
        rh_status_q || exit 7  
        upgrade  
        ;;  
    reload)  
        rh_status_q || exit 7  
        $1  
        ;;  
    status|status_q)  
        rh_$1  
        ;;  
    condrestart|try-restart)  
        rh_status_q || exit 7  
        restart  
        ;;  
    *)  
        echo $"Usage: $0 {start|stop|reload|configtest|status|force-reload|upgrade|restart|reopen_logs}"  
        exit 2  
esac  
--------------------------file end---------------------------------  
    开机启动  
        ~]# chkconfig --add nginx  
        ~]# chkconfig --level 345 nginx on  
        ~]# chkconfig --list nginx  
            nginx           0:off   1:off   2:off   3:on    4:on    5:on    6:off  

    开机不启动  
        ~]# chkconfig nginx off  
        ~]# chkconfig --list nginx  
            nginx           0:off   1:off   2:off   3:off   4:off   5:off   6:off  




CentOS 7:  
    ~]# vi /usr/lib/systemd/system/nginx.service  
--------------------------file start---------------------------------  
[Unit]    
Description=nginx    
After=network.target remote-fs.target nss-lookup.target  

[Service]    
Type=forking  
ExecStart=/usr/local/nginx/sbin/nginx    
ExecReload=/usr/local/nginx/sbin/nginx -s reload  
ExecStop=/usr/local/nginx/sbin/nginx -s  stop  
PrivateTmp=true    

[Install]    
WantedBy=multi-user.target  
--------------------------file end---------------------------------  

    开机启动  
        ~]# systemctl enable nginx.service  
    开机不启动  
        ~]# systemctl disable nginx.service  
    其他操作:  
        ~]# systemcl ( status | start | stop | reload | restart ) nginx.service  


    其他操作:  
        ~]# service nginx (start|stop|reload|configtest|status|force-reload|upgrade|restart|reopen_logs)  
在使用Python来安装geopandas包时,由于geopandas依赖于几个其他的Python库(如GDAL, Fiona, Pyproj, Shapely等),因此安装过程可能需要一些额外的步骤。以下是一个基本的安装指南,适用于大多数用户: 使用pip安装 确保Python和pip已安装: 首先,确保你的计算机上已安装了Python和pip。pip是Python的包管理工具,用于安装和管理Python包。 安装依赖库: 由于geopandas依赖于GDAL, Fiona, Pyproj, Shapely等库,你可能需要先安装这些库。通常,你可以通过pip直接安装这些库,但有时候可能需要从其他源下载预编译的二进制包(wheel文件),特别是GDAL和Fiona,因为它们可能包含一些系统级的依赖。 bash pip install GDAL Fiona Pyproj Shapely 注意:在某些系统上,直接使用pip安装GDAL和Fiona可能会遇到问题,因为它们需要编译一些C/C++代码。如果遇到问题,你可以考虑使用conda(一个Python包、依赖和环境管理器)来安装这些库,或者从Unofficial Windows Binaries for Python Extension Packages这样的网站下载预编译的wheel文件。 安装geopandas: 在安装了所有依赖库之后,你可以使用pip来安装geopandas。 bash pip install geopandas 使用conda安装 如果你正在使用conda作为你的Python包管理器,那么安装geopandas和它的依赖可能会更简单一些。 创建一个新的conda环境(可选,但推荐): bash conda create -n geoenv python=3.x anaconda conda activate geoenv 其中3.x是你希望使用的Python版本。 安装geopandas: 使用conda-forge频道来安装geopandas,因为它提供了许多地理空间相关的包。 bash conda install -c conda-forge geopandas 这条命令会自动安装geopandas及其所有依赖。 注意事项 如果你在安装过程中遇到任何问题,比如编译错误或依赖问题,请检查你的Python版本和pip/conda的版本是否是最新的,或者尝试在不同的环境中安装。 某些库(如GDAL)可能需要额外的系统级依赖,如地理空间库(如PROJ和GEOS)。这些依赖可能需要单独安装,具体取决于你的操作系统。 如果你在Windows上遇到问题,并且pip安装失败,尝试从Unofficial Windows Binaries for Python Extension Packages网站下载相应的wheel文件,并使用pip进行安装。 脚本示例 虽然你的问题主要是关于如何安装geopandas,但如果你想要一个Python脚本来重命名文件夹下的文件,在原始名字前面加上字符串"geopandas",以下是一个简单的示例: python import os # 指定文件夹路径 folder_path = 'path/to/your/folder' # 遍历文件夹中的文件 for filename in os.listdir(folder_path): # 构造原始文件路径 old_file_path = os.path.join(folder_path, filename) # 构造新文件名 new_filename = 'geopandas_' + filename # 构造新文件路径 new_file_path = os.path.join(folder_path, new_filename) # 重命名文件 os.rename(old_file_path, new_file_path) print(f'Renamed "{filename}" to "{new_filename}"') 请确保将'path/to/your/folder'替换为你想要重命名文件的实际文件夹路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值