服务器的负载能力,很大程度上取决于系统管理员的配置和优化能力。相同的硬件、不同的软件配置,会造成截然不同的效果。下面我将给大家介绍一下如何优化 sysctrl, Apache 以及 MySQL 。请注意,所有配置均为取决于个人,请根据自己的实际情况做调整。

配置Sysctl

编辑此文件:

nano -w /etc/sysctl.conf

如果该文件为空,则输入以下内容,否则请根据情况自己做调整:

# Controls source route verification

# Default should work for all interfaces

net.ipv4.conf.default.rp_filter = 1

# net.ipv4.conf.all.rp_filter = 1

# net.ipv4.conf.lo.rp_filter = 1

# net.ipv4.conf.eth0.rp_filter = 1

# Disables IP source routing

# Default should work for all interfaces

net.ipv4.conf.default.accept_source_route = 0

# net.ipv4.conf.all.accept_source_route = 0

# net.ipv4.conf.lo.accept_source_route = 0

# net.ipv4.conf.eth0.accept_source_route = 0

# Controls the System Request debugging functionality of the kernel

kernel.sysrq = 0

# Controls whether core dumps will append the PID to the core filename.

# Useful for debugging multi-threaded applications.

kernel.core_uses_pid = 1

# Increase maximum amount of memory allocated to shm

# Only uncomment if needed!

# kernel.shmmax = 67108864

# Disable ICMP Redirect Acceptance

# Default should work for all interfaces

net.ipv4.conf.default.accept_redirects = 0

# net.ipv4.conf.all.accept_redirects = 0

# net.ipv4.conf.lo.accept_redirects = 0

# net.ipv4.conf.eth0.accept_redirects = 0

# Enable Log Spoofed Packets, Source Routed Packets, Redirect Packets

# Default should work for all interfaces

net.ipv4.conf.default.log_martians = 1

# net.ipv4.conf.all.log_martians = 1

# net.ipv4.conf.lo.log_martians = 1

# net.ipv4.conf.eth0.log_martians = 1

# Decrease the time default value for tcp_fin_timeout connection

net.ipv4.tcp_fin_timeout = 25

# Decrease the time default value for tcp_keepalive_time connection

net.ipv4.tcp_keepalive_time = 1200

# Turn on the tcp_window_scaling

net.ipv4.tcp_window_scaling = 1

# Turn on the tcp_sack

net.ipv4.tcp_sack = 1

# tcp_fack should be on because of sack

net.ipv4.tcp_fack = 1

# Turn on the tcp_timestamps

net.ipv4.tcp_timestamps = 1

# Enable TCP SYN Cookie Protection

net.ipv4.tcp_syncookies = 1

# Enable ignoring broadcasts request

net.ipv4.icmp_echo_ignore_broadcasts = 1

# Enable bad error message Protection

net.ipv4.icmp_ignore_bogus_error_responses = 1

# Make more local ports available

# net.ipv4.ip_local_port_range = 1024 65000

# Set TCP Re-Ordering value in kernel to ‘5′

net.ipv4.tcp_reordering = 5

# Lower syn retry rates

net.ipv4.tcp_synack_retries = 2

net.ipv4.tcp_syn_retries = 3

# Set Max SYN Backlog to ‘2048′

net.ipv4.tcp_max_syn_backlog = 2048

# Various Settings

net.core.netdev_max_backlog = 1024

# Increase the maximum number of skb-heads to be cached

net.core.hot_list_length = 256

# Increase the tcp-time-wait buckets pool size

net.ipv4.tcp_max_tw_buckets = 360000

# This will increase the amount of memory available for socket input/output queues

net.core.rmem_default = 65535

net.core.rmem_max = 8388608

net.ipv4.tcp_rmem = 4096 87380 8388608

net.core.wmem_default = 65535

net.core.wmem_max = 8388608

net.ipv4.tcp_wmem = 4096 65535 8388608

net.ipv4.tcp_mem = 8388608 8388608 8388608

net.core.optmem_max = 40960

如果希望屏蔽别人 ping 你的主机,则加入以下代码:

# Disable ping requests

net.ipv4.icmp_echo_ignore_all = 1

编辑完成后,请执行以下命令使变动立即生效:

/sbin/sysctl -p

/sbin/sysctl -w net.ipv4.route.flush=1

MySQL优化

编辑MySQL的配置文件:

nano /etc/my.cnf

输入以下内容:

[mysqld]

connect_timeout=15

interactive_timeout=100

join_buffer_size=1M

key_buffer=128M

max_allowed_packet=16M

max_connections=500

max_connect_errors=10

myisam_sort_buffer_size=64M

read_buffer_size=1M

read_rnd_buffer_size=768K

sort_buffer_size=1M

table_cache=1024

thread_cache_size=100

thread_concurrency=4

wait_timeout=300

query_cache_size=32M

query_cache_limit=1M

query_cache_type=1

skip-innodb

请注意,以上配置适用于512M~1024M内存,如内存更大的话请自行做调整。给项目增加内存会加快速度,但是使用过多的内存而导致启用swap的话,会极大的导致系统效率下降。其中 thread_concurrency 这项配置,单CPU的话请设置为2,双CPU的话请设置为4。

Apache优化

以下优化适用于 Apache 1.3 系列,如果你用的是 2.0 系列的话,请自行做调整和判断。

确认 Apache 的配置文件位置并开始编辑:

locate httpd.conf

nano -w /path/to/httpd.conf

httpd.conf的文件有许多内容,笔者就拿出需要做优化的:

KeepAlive On

MaxKeepAliveRequests 1000

KeepAliveTimeout 3

MinSpareServers 8

MaxSpareServers 13

MaxRequestsPerChild 50

将 KeepAliveTimeout 设定到较小的数字将有助于减少服务器上的无用等待链接,一定程度上能增加服务器负载。

另外,下面这条不算优化,但是是Apache安全相关:

ServerSignature Off

ServerTokens ProductOnly

将 ServerSignature 关闭,并增加 ServerTokens ProductOnly 可以使常人无法检测到Apache的实际版本号,有助于Apache的安全。

以上所做的这些优化在某种程度上会增强服务器的负载性能。

sysctl mysql_服务器优化——Sysctl、Apache、MySQL相关推荐

  1. 导入失败 mysql_服务器宕机导致mysql出问题的处理方法

    点上方蓝字"工控先生"免费快速关注 本文由"135编辑器 在工作中,我们会遇到由于服务器突然断电,导致mysql数据库启动失败,这个启动失败大部分都是由于数据库本身的文件 ...

  2. Linux+Apache+Mysql+PHP典型配置

    版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明 http://www.5ilinux.com/lamp01.html 关键字:apache+mysql+php ap ...

  3. 构建安全的apache+mysql+php的web服务器

    原贴:http://blog.chinaunix.net/u/13329/showart.php?id=99256 构建安全的apache+mysql+php的web服务器     * 作者:heiy ...

  4. apache mysql php实现最大负载的方法_如何架设高性能nginx+php+mysql搭配的服务器,解决高并发问题...

    很多站长会发现把网站发布到服务器上后,网站访问速度很慢.这个对网站来说是个致命伤,网站相应速度慢,即使网站做的很漂亮,内容很完整,客户打开蜗牛一样的也会失去耐心,可能直接关闭网站离开,这样就导致用户流 ...

  5. mac 下搭建 php + apache + mysql 服务器(cool)

    之前做.net 网站.后转ios .所有很少接触windows 啦.但有时候自己还真需要个测试的服务器环境.干脆把自己电脑搞成服务器得了 下面贴上链接: Apache+PHP+Mysql OS X 1 ...

  6. 云服务器apache mysql php_服务器配置教程:阿里云服务器安装PHP环境(附PHP+MySQL+Apache后台小Demo)...

    前言 搭建Apache HTTP Server往往都会安装PHP环境,因为很多人都使用PHP做web.其实相对我而言,我是用PHP做后台.主要是因为我是移动端方向:做iOS和Android.往往需要通 ...

  7. 宝塔apache mysql_商淘多商户商城系统部署之宝塔面板(Nginx/Apache+MySQL+PHP7.1)

    前置说明: 1).准备阿里云服务空间,如果有域名则需要将域名指向到阿里云远程IP上. 2).在linux下安装好BT面板.(参考:https://www.bt.cn/bbs/thread-19376- ...

  8. 阿里云centos mysql_阿里云ECS服务器CentOS7上安装MySql服务-阿里云开发者社区

    阿里云ECS服务器CentOS7上安装MySql服务 ---------------------------------------------- 使用root登录 1.确保服务器系统处于最新状态 [ ...

  9. centos安装php服务器,在CentOS上安装搭建PHP+Apache+Mysql的服务器环境方法

    以下安装过程是基于centos下,使用yum安装搭建PHP+Apache+Mysql的服务器环境 一:安装MySQL 1.安装yum install mysql mysql-server mysql- ...

最新文章

  1. Android studio 获取每次编译apk时的日期
  2. python内置模块re_Python常用内建模块-re模块(正则表达式)
  3. 红帽目录服务的数据导入导出
  4. 获取相册所有uri_URI转码
  5. sql 新增加一列序号_取出上一条下一条的 sql语句
  6. 三思笔记,涂抹ORACLE
  7. 研磨设计模式--外观模式
  8. 邮箱服务器未运行,smtp服务器,smtp服务器未设置
  9. php使用cookie获取浏览记录,php使用cookie存库浏览记录详解
  10. K8S-Kubeadm的安装及原理
  11. 计算机图像相关应用研究,计算机图像处理技术的应用探讨.pdf
  12. 在html里ff3d3d是什么颜色,HTML一些颜色方面的参考
  13. JVM 垃圾收集算法及垃圾收集器
  14. MinIO集群怎么接入Prometheus监控?(上)
  15. 重来之大学版|社交生活篇——失恋了怎么办?失恋了很难受怎么办?如何走出失恋的痛苦?我失恋了该怎么办?如何从失恋的痛苦中走出来?
  16. 清华-计算机-考研-精华帖-汇总
  17. 字符串中空格符 空字符
  18. Google浏览器网页,大部分网页出现无法加载样式
  19. pytest-daytwo(fixture、allure等概论,并没有完全懂,后续再详细写)
  20. PDF文档转Word为什么文字都是乱码,怎么解决?

热门文章

  1. mdi 子窗体 菜单 不合并。
  2. [Silverlight入门系列]使用MVVM模式(1):MVVM核心概念
  3. 华为云+AI,视频分析全面进入智能时代
  4. 初学微信小程序 TodoList
  5. js、jquery实用小技巧集合
  6. Dbml文件提取建表TSql-CodeSmith
  7. CentOS7编译安装nginx-1.8.1和编译参数
  8. facebook 分享,遇到的错误
  9. 傻瓜式图文教你在linux下搭建VNC服务器
  10. 对 Accordion 组件使用样式