about nginx

1.安装nginx
运行:
sudo apt-get intsall nginx
Ubuntu安装之后的文件结构大致为:
* 所有的配置文件都在/etc/nginx下,并且每个虚拟主机已经安排在了/etc/nginx/sites-available下
* 程序文件在/usr/sbin/nginx
* 日志放在了/var/log/nginx中
* 并已经在/etc/init.d/下创建了启动脚本nginx




* 默认的虚拟主机的目录设置在了/var/www/nginx-default
下面可以启动nginx来看看效果(请确保80端口没有其他服务在使用):
Ubuntu请运行:
sudo /etc/init.d/nginx start
然后打开浏览器,查看http://localhost/ 看看是否看到了“Welcome to nginx!” 如果看到了,说明安装成功。当然,基本上,这块儿都不会出问题。
如果运行不成功,可以先 sudo killall apache2 杀掉apache进程
2.安装php:
当然,现在我们都用php5了。运行:
sudo apt-get install php5 php5-cgi php5-mysql php5-curl php5-gd php5-idn php-pear php5-imagick php5-imap php5-mcrypt php5-memcache php5-mhash php5-ming php5-pspell php5-recode php5-snmp php5-tidy php5-xmlrpc php5-sqlite php5-xsl

3.安装spawn-fcgi
运行sudo apt-get install spawn-fcgi
为什么要安装spawn- fcgi呢,它用来控制php-cgi进程,以防止进程崩溃或是单进程的效率太低。
网上很多人都说要使用spawn-fcgi必须得安装 lighttpd,实际上不必要,可以直接安装spawn-fcgi

接下来就是最让人头疼的配置。
配置Nginx和spawn-fcgi配合运行
(1).在/etc/nginx /fastcgi_params 文件最后,加入一行,可以用sudo gedit /etc/nginx/fastcgi_params打开文件
加入此行:fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

(2).另外需要在PHP-CGI的配置文件(Ubuntu 上此配置文件位于/etc/php5/cgi/php.ini)中,找到cgi.fix_pathinfo选项,修改为:
cgi.fix_pathinfo=1;
这样php-cgi方能正常使用SCRIPT_FILENAME这个变量。

(3).打开/etc/nginx/sites-available/default文件

server {
listen 80;
server_name localhost;

下面添加
root /var/www/nginx-default
即root和server_name同级
这段即相当于 apache的默认目录 如果没有这个的话,容易在执行php 文件的时候,会提示”No input file specified”。我就曾在此绕了好大个圈子才发现问题。

然后修改
#location ~ \.php$ {
#fastcgi_pass 127.0.0.1:9000;
#fastcgi_index index.php;
#fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
#includefastcgi_params;
#}

修改成

location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
#fastcgi_param SCRIPT_FILENAME /var/www/nginx-default$fastcgi_script_name; 这段没啥用了,留在这儿做个提醒而已
include /etc/nginx/fastcgi_params; #fastcgi的参数文件地址
}

然后运行
sudo /usr/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 5 -u www-data -g www-data -f /usr/bin/php5-cgi -P /var/run/fastcgi-php.pid
来启动fast-cgi进程,然后我们可以将这行代码加入到/etc/rc.local文件底部,这样系统启动的时候也可以同时启动PHP的FastCGI 进程。

再运行sudo /etc/init.d/nginx restart 重启nginx
好了,可以把你的php文件放在/var/www /nginx-default下面来测试一下了。

如果打开php文件出现:No input file specified
请检查
php.ini的配置中
cgi.fix_pathinfo=1
doc_root=
还有,每个虚机要根据自己不通的虚机设置不能的目录,要保证这个路径正确。
检查/etc/nginx/sites-available下的配置文件中,server内包含 root 及地址 而非location内的root

附重启nginx和php-cgi 的命令

nginx: sudo /etc/init.d/nginx restart 同样也可以有start,stop等参数
php-cgi: 先杀死进程
sudo killall -HUP php5-cgi
再启动
sudo /usr/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 5 -u www-data -g www-data -f /usr/bin/php5-cgi -P /var/run/fastcgi-php.pid

参数含义如下

* -f 指定调用FastCGI的进程的执行程序位置,根据系统上所装的PHP的情况具体设置
* -a 绑定到地址addr
* -p 绑定到端口port
* -s 绑定到unix socket的路径path
* -C 指定产生的FastCGI的进程数,默认为5(仅用于PHP)
* -P
指定产生的进程的PID文件路径
* -u和-g FastCGI使用什么身份(-u 用户 -g 用户组)运行,Ubuntu下可以使用www-data,其他的根据情况配置,如nobody、apache等
———————————-
如果要安装 zendOptimizer
先去zend官网下载,地址http://www.zend.com/en/products/guard /downloads
找对应你操作系统的zendOptimizer,如果下载过程中要求注册,而你没有注册过,那就不防注册一次,一劳永逸。
然后解压,打开data文件夹,再找出对应你php版本的so文件。基本上现在都是php5.2了,所以在 5_2_x_comp/ZendOptimizer.so
可以把这个文件放在任何位置,只要在php.ini中指定出绝对位置就行。
比如我们将其放在/usr/local下面。
sudo mkdir /usr/local/zend //按提示输入密码
在你解压出的文件夹内,执行
sudo cp ZendOptimizer.so /usr/local/zend
将这个文件拷过去。
编辑 php.ini ,在终端输入
sudo gedit /etc/php5/cgi/php.ini
在文件末尾加入
[Zend Optimizer]
zend_optimizer.optimization_level=1
zend_extension=”/usr/local/zend/ZendOptimizer.so”

然后重启fastcgi
sudo killall -HUP php5-cgi
再启动
sudo /usr/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 5 -u www-data -g www-data -f /usr/bin/php5-cgi -P /var/run/fastcgi-php.pid
OK了。用php探针看看吧。
4、安装 PHP和MySQL
sudo apt-get install mysql-server mysql-client
中间会提示输入 Root用户密码,依次输入即可。

启动MySQL
sudo /etc/init.d/mysql start

mysql -uroot -p
输入mysql密码
mysql> show databases;
+——————–+
| Database |
+——————–+
| information_schema |
| mysql |
+——————–+
mysql 已正确安装了。
基于数据驱动的 Koopman 算子的递归神经网络模型线性化,用于纳米定位系统的预测控制研究(Matlab代码实现)内容概要:本文围绕“基于数据驱动的Koopman算子的递归神经网络模型线性化”展开,旨在研究纳米定位系统的预测控制方法。通过结合数据驱动技术与Koopman算子理论,将非线性系统动态近似为高维线性系统,进而利用递归神经网络(RNN)建模并实现系统行为的精确预测。文中详细阐述了模型构建流程、线性化策略及在预测控制中的集成应用,并提供了完整的Matlab代码实现,便于科研人员复现实验、优化算法并拓展至其他精密控制系统。该方法有效提升了纳米级定位系统的控制精度与动态响应性能。; 适合人群:具备自动控制、机器学习或信号处理背景,熟悉Matlab编程,从事精密仪器控制、智能制造或先进控制算法研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①实现非线性动态系统的数据驱动线性化建模;②提升纳米定位平台的轨迹跟踪与预测控制性能;③为高精度控制系统提供可复现的Koopman-RNN融合解决方案; 阅读建议:建议结合Matlab代码逐段理解算法实现细节,重点关注Koopman观测矩阵构造、RNN训练流程与模型预测控制器(MPC)的集成方式,鼓励在实际硬件平台上验证并调整参数以适应具体应用场景。
### 解决 OpenSSL 版本冲突问题并成功安装 Nginx 在 Red Hat 系列操作系统中,Nginx 安装过程可能会因为 OpenSSL 的版本冲突(如 `1:openssl-1.0.2k-21.el7_9.x86_64` 和 `1:openssl-1.0.2k-26.el7_9.x86_64`)而导致失败。这是由于多架构支持机制中的保护策略触发所致。以下是详细的解决方案: --- #### **1. 分析 OpenSSL 版本冲突的原因** Red Hat 系统启用了多架构支持(Multilib),用于在同一系统中同时管理 32 位和 64 位软件包。然而,这种机制会对相同名称但不同版本的软件包施加严格的版本一致性检查。如果检测到不一致的版本组合,则会抛出类似于以下的错误消息: ``` Error: Protected multilib versions: 1:openssl-libs-1.0.2k-26.el7_9.x86_64 != 1:openssl-libs-1.0.2k-21.el7_9.x86_64 ``` 这意味着系统中存在两个不同的 OpenSSL 软件包版本,分别对应于 i686 (32-bit) 和 x86_64 (64-bit),这违反了 Multilib 的设计原则[^3]。 --- #### **2. 解决方案** 以下是几种常见的解决方法,可根据具体情况进行选择: ##### 方法一:同步 OpenSSL 软件包版本 通过强制升级或降级的方式使所有相关软件包保持同一版本号。例如,将较低版本升级至较高版本: ```bash yum update openssl openssl-libs -y ``` 或者将较高版本降级至较低版本: ```bash yum downgrade openssl-1.0.2k-21.el7_9.x86_64 openssl-libs-1.0.2k-21.el7_9.x86_64 -y ``` 注意:此操作可能会影响其他依赖组件的功能,请提前备份重要数据并评估风险。 ##### 方法二:禁用 Multilib 检查 临时关闭 RPM 的多架构保护功能以允许安装不匹配的版本: ```bash echo "%_multilib_protect_all 0" > /etc/rpm/macros.multilib yum clean all yum reinstall openssl openssl-libs -y ``` 完成后再移除宏配置文件恢复默认设置: ```bash rm -f /etc/rpm/macros.multilib ``` ##### 方法三:手动编译安装自定义 OpenSSL 如果官方仓库无法满足需求,可以选择从源码编译最新稳定版 OpenSSL 并指定路径供 Nginx 使用: ```bash wget https://www.openssl.org/source/openssl-1.1.1n.tar.gz tar zxvf openssl-1.1.1n.tar.gz cd openssl-1.1.1n/ ./config --prefix=/usr/local/ssl shared zlib-dynamic make && make install ``` 随后,在编译 Nginx 时显式指向该目录下的头文件和库文件: ```bash ./configure --with-openssl=/path/to/custom/openssl ... make && make install ``` --- #### **3. 验证修复结果** 确认 OpenSSL 冲突已被妥善处理后,继续安装 Nginx: ```bash yum install epel-release -y yum install nginx -y systemctl start nginx systemctl enable nginx ``` 最后验证服务状态是否正常启动: ```bash systemctl status nginx ``` --- #### **4. 推荐最佳实践** 为了避免类似的依赖冲突问题再次发生,建议采取以下措施: - 尽量使用官方提供的软件包而非混搭第三方资源; - 定期更新基础镜像以获取最新的安全补丁和支持; - 在生产环境中实施变更前务必先进行充分测试。 --- ### 总结 以上介绍了针对 OpenSSL 版本冲突的具体应对办法及其背后原理分析,并给出了完整的 Nginx 安装流程指导。无论采用哪种途径解决问题,都需权衡利弊并做好应急预案准备。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值