├── .gitignore ├── README.md ├── admin ├── details.html ├── footer.php ├── header.php ├── help.html ├── index.html ├── index.raw ├── saved.html ├── settings.html └── widgets │ └── WGT_PLUGINS_ADMIN_LOAD_MONITOR │ ├── main.html │ ├── tab.html │ └── url.html ├── data └── README.md ├── exec ├── add.php ├── add.sh ├── bootstrap.php ├── clean.php ├── config.ini.default ├── functions.php ├── install-cron.c ├── parseInputs.php └── vacuum.php ├── hooks └── admin_txt.html ├── load_monitor.png ├── load_monitor_widget.png ├── php.ini ├── plugin.conf ├── scripts ├── install.sh ├── install_cron.php ├── install_cron.sh ├── install_db.php ├── install_db.sh ├── uninstall.sh └── update.sh └── version.txt /.gitignore: -------------------------------------------------------------------------------- 1 | data/load_monitor.sqlite 2 | data/top.raw* 3 | exec/config.ini 4 | exec/install-cron 5 | available_version.txt 6 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Name 2 | 3 | Load Monitor 4 | 5 | ![Load Monitor Widget Preview in Evoution Skin](https://raw.githubusercontent.com/poralix/load_monitor/master/load_monitor_widget.png) 6 | 7 | # Version 8 | 9 | - Patched version: 0.2.9 (by Alex S Grebenschikov) 10 | - Original version: 0.1 (written by Future Vision) 11 | 12 | # Changes history: 13 | 14 | - 0.2.9: Fixed a bug related to `top` parsing of total available Swap and RAM 15 | - 0.2.8: Setting Language to en_US.UTF-8 before parsing `top` output 16 | - 0.2.6: Minor update is done to enable updates of the plugin via Directadmin interface 17 | - 0.2.5: Minor changes: to use own php.ini. A fix for Debian 8 added. 18 | - 0.2.4: An admin widget added for Evolution skin 19 | - 0.2.3: Updated to work under Evolution skin 20 | 21 | # Description 22 | 23 | Load monitor plugin for Directadmin 24 | 25 | # Author 26 | 27 | - Originally written by: Future Vision 28 | - Patched by: Alex S Grebenschikov (www.poralix.com) 29 | 30 | 31 | # Installation 32 | 33 | ``` 34 | cd /usr/local/directadmin/plugins/ 35 | git clone https://github.com/poralix/load_monitor.git 36 | cd load_monitor/scripts/ 37 | ./install.sh 38 | ``` 39 | 40 | Go to Directadmin panel as admin and click "Load Monitor" 41 | 42 | Then go to the plugin settings and update: 43 | 44 | - Maximum days to remember loads: default 91 (0 = all, more days = more space) 45 | - Maximum task entries to save: default 91 (0 = all, more tasks = more space) 46 | - Save interval in minutes: default 1 47 | 48 | 91 days of data with 1 minutes intervals might take up to 2Gb disk space and more. 49 | 50 | 51 | # Warnings and requirements 52 | 53 | Time Zone is taken from `/usr/local/directadmin/custombuild/options.conf`. Make sure the value of `php_timezone=` corresponds to your actual Time Zone. 54 | 55 | The plugin loads JavaScript files from Google to draw graphs, i.e. it uses Google's libraries for drawing graphs. Your browser should be allowed to load JS from Google. 56 | 57 | Supported and tested OS: 58 | 59 | - CentOS 6, 7, 8 60 | - Debian 8 61 | 62 | Potentially can work under Debian versions (not tested though). 63 | 64 | # FAQ: 65 | 66 | - Q: Time zone is wrong what to do? 67 | - A: Change Time Zone in `php_timezone=` of `/usr/local/directadmin/custombuild/options.conf`. And update the plugin. 68 | 69 | # Have ideas? 70 | 71 | Please feel free to use it and let us know your thoughts and ideas for improvements. 72 | -------------------------------------------------------------------------------- /admin/details.html: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | query('SELECT * FROM loads WHERE DATETIME(created) = "' . $created . '" LIMIT 1'); 26 | $r = $loadRow->fetch(); 27 | $tasks = json_decode(base64_decode($r['tasks']), true); 28 | 29 | require_once dirname(__FILE__) . '/header.php'; 30 | ?> 31 | 32 |
33 | 34 | 35 | 36 | 37 | 38 | 39 |
Load Monitor
Showing server load on
40 |
41 |
42 | 43 | '; 45 | echo 'top - '. $r['created'] .' up '. $r['uptime'] .', '. $r['users'] .' user, load average: '. $r['one'] .', '. $r['five'] .', '. $r['fifteen'] .'
'; 46 | echo 'Tasks: '. $r['task_total'] .' total, '. $r['task_running'] .' running, '. $r['task_sleeping'] .' sleeping, '. $r['task_stopped'] .' stopped, '. $r['task_zombie'] .' zombie
'; 47 | echo 'Cpu(s): '. $r['cpu_us'] .'%us, '. $r['cpu_sy'] .'%sy, '. $r['cpu_ni'] .'%ni, '. $r['cpu_id'] .'%id, '. $r['cpu_wa'] .'%wa, '. $r['cpu_hi'] .'%hi, '. $r['cpu_si'] .'%si, '. $r['cpu_st'] .'%st
'; 48 | echo 'Mem: '. $r['mem_total'] .'k total, '. $r['mem_used'] .'k used, '. $r['mem_free'] .'k free, '. $r['mem_buffers'] .'k buffers
'; 49 | echo 'Swap: '. $r['swap_total'] .'k total, '. $r['swap_used'] .'k used, '. $r['swap_free'] .'k free, '. $r['swap_cached'] .'k cached'; 50 | echo ''; 51 | echo '
'; 52 | ?> 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | '; 76 | echo ''; 77 | echo ''; 78 | echo ''; 79 | echo ''; 80 | echo ''; 81 | echo ''; 82 | echo ''; 83 | echo ''; 84 | echo ''; 85 | echo ''; 86 | echo ''; 87 | echo ''; 88 | echo ''; 89 | } 90 | echo '
PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND
'.$task['pid'].''.$task['user'].''.$task['pr'].''.$task['ni'].''.$task['virt'].''.$task['res'].''.$task['shr'].''.$task['s'].''.$task['cpu'].''.$task['mem'].''.$task['time'].''.$task['cmd'].'
'; 91 | require_once dirname(__FILE__) . '/footer.php'; 92 | 93 | ?> -------------------------------------------------------------------------------- /admin/footer.php: -------------------------------------------------------------------------------- 1 | 17 |

18 |
19 | Settings | Plugin Home 20 |
21 |
Load Monitor was Originally written by Future Vision, patched and updated by Poralix.com, 2018-2019 22 |
23 | 26 | -------------------------------------------------------------------------------- /admin/header.php: -------------------------------------------------------------------------------- 1 | 20 | 43 | 21 | 22 | 23 | 24 | 27 | 28 | 29 | 30 | 39 | 40 | 41 | 46 | 47 | 48 | 49 | 72 | 73 | 74 | 75 | 80 | 81 |
25 |

Load Monitor - Help

26 |
31 |

32 | Support Notes from Future Vision 33 |
34 |
35 | This plugin should not break anything but comes without support or warranty.
36 | I am not responsible for any damage to your server. 37 |

38 |
42 | 43 | 44 |
45 |
50 |

51 | Installation 52 |
53 |
54 | After installation trough DirectAdmin no data is showing up, this is normal.
55 | The script 'add.sh' should be called preferably by crontab to work, this can
56 | be done by running 'install_cron.sh' in '/usr/local/directadmin/plugins/load_monitor/'
57 | (it should keep current crontab intact, but do it at your own risk!) or
58 | by adding it manually to crontab using 'crontab -e': 59 |
60 |
61 | */5 * * * * cd /usr/local/directadmin/plugins/load_monitor/exec/; ./add.sh; 62 |
63 |
64 | The '5' in the command is the interval in minutes the script should run in (5 by default), 65 |
66 | change this if you like but be aware your machine might slow down if you call the script too often. 67 |
68 |
69 | Make sure the exec is added under the root user or otherwise it might not collect all data you want. 70 |

71 |
76 | 77 | 78 |
79 |
82 | 83 | 84 | -------------------------------------------------------------------------------- /admin/index.html: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | query('SELECT strftime("%Y-%m-%d", created) as day FROM loads GROUP BY DATE(created)'); 35 | $loadRows = $db->query('SELECT one, five, fifteen, strftime("%H:%M", created) as curtime, created FROM loads WHERE DATETIME(created) BETWEEN "' . $start . '" AND "' . $end . '"'); 36 | 37 | $loads = array(); 38 | foreach($loadRows as $loadRow) { 39 | $loads[] = array( 40 | 'created' => $loadRow['created'], 41 | 'curtime' => $loadRow['curtime'], 42 | 'one' => $loadRow['one'], 43 | 'five' => $loadRow['five'], 44 | 'fifteen' => $loadRow['fifteen'] 45 | ); 46 | } 47 | 48 | require_once dirname(__FILE__) . '/header.php'; 49 | ?> 50 | 51 | 52 | 96 | 97 |
98 | 99 | 100 | 101 | 102 | 117 | 118 | 133 | 134 | 135 |
Load Monitor
Day 103 | 116 | Period 119 | 132 |
Show current  
136 |
137 |
138 | 139 | 140 | 141 | 144 | 145 | 146 |
142 |
143 |
147 | 148 | 149 | -------------------------------------------------------------------------------- /admin/index.raw: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | query('SELECT strftime("%Y-%m-%d", created) as day FROM loads GROUP BY DATE(created)'); 28 | $loadRows = $db->query('SELECT one, five, fifteen, strftime("%H:%M", created) as curtime, created FROM loads WHERE DATETIME(created) BETWEEN "' . $start . '" AND "' . $end . '"'); 29 | 30 | $loads = array(); 31 | foreach($loadRows as $loadRow) { 32 | $loads[] = array( 33 | 'created' => $loadRow['created'], 34 | 'curtime' => $loadRow['curtime'], 35 | 'one' => $loadRow['one'], 36 | 'five' => $loadRow['five'], 37 | 'fifteen' => $loadRow['fifteen'] 38 | ); 39 | } 40 | 41 | require_once dirname(__FILE__) . '/header.php'; 42 | ?> 43 | 44 | 45 | 89 | 90 | '; 93 | print '
Server time: '. date('r') .'
'; 94 | -------------------------------------------------------------------------------- /admin/saved.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 7 | 8 | 9 | 14 | 15 | 16 | 20 | 21 |
5 |

Config saved

6 |
10 | 11 | 12 |
13 |
17 |

View Load Monitor

18 |

19 |
22 | 23 | -------------------------------------------------------------------------------- /admin/settings.html: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | 33 | 34 | 35 | 38 | 39 | 40 | 45 | 46 | 47 | 51 | 52 |
36 |

Settings saved

37 |
41 | 42 | 43 |
44 |
48 |

Back to Load Monitor

49 |

50 |
53 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 |
Load Monitor - Settings
Maximum days to remember loads:> (0 = all, more days = more space)
Maximum task entries to save:> (0 = all, more tasks = more space)
Save interval in minutes:>
  
Color 1 Minute:>
Color 5 Minutes:>
Color 15 minutes:>
71 | 72 | -------------------------------------------------------------------------------- /admin/widgets/WGT_PLUGINS_ADMIN_LOAD_MONITOR/main.html: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | Load Monitor'; 19 | print ''; 20 | -------------------------------------------------------------------------------- /admin/widgets/WGT_PLUGINS_ADMIN_LOAD_MONITOR/tab.html: -------------------------------------------------------------------------------- 1 | #!/usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini 2 | $task[0], 92 | 'user' => $task[1], 93 | 'pr' => $task[2], 94 | 'ni' => $task[3], 95 | 'virt' => $task[4], 96 | 'res' => $task[5], 97 | 'shr' => $task[6], 98 | 's' => $task[7], 99 | 'cpu' => $task[8], 100 | 'mem' => $task[9], 101 | 'time' => $task[10], 102 | 'cmd' => $task[11] 103 | ); 104 | } 105 | 106 | $fields = array( 107 | 'created', 108 | 'uptime', 109 | 'users', 110 | 'one', 111 | 'five', 112 | 'fifteen', 113 | 'task_total', 114 | 'task_running', 115 | 'task_sleeping', 116 | 'task_stopped', 117 | 'task_zombie', 118 | 'cpu_us', 119 | 'cpu_sy', 120 | 'cpu_ni', 121 | 'cpu_id', 122 | 'cpu_wa', 123 | 'cpu_hi', 124 | 'cpu_si', 125 | 'cpu_st', 126 | 'mem_total', 127 | 'mem_used', 128 | 'mem_free', 129 | 'mem_buffers', 130 | 'swap_total', 131 | 'swap_used', 132 | 'swap_free', 133 | 'swap_cached', 134 | 'tasks' 135 | ); 136 | 137 | $values = array( 138 | '"' . date('Y-m-d H:i:s') . '"', 139 | '"' . $save['uptime'] . '"', 140 | $save['users'], 141 | $save['one'], 142 | $save['five'], 143 | $save['fifteen'], 144 | $save['task_total'], 145 | $save['task_running'], 146 | $save['task_sleeping'], 147 | $save['task_stopped'], 148 | $save['task_zombie'], 149 | $save['cpu_us'], 150 | $save['cpu_sy'], 151 | $save['cpu_ni'], 152 | $save['cpu_id'], 153 | $save['cpu_wa'], 154 | $save['cpu_hi'], 155 | $save['cpu_si'], 156 | $save['cpu_st'], 157 | $save['mem_total'], 158 | $save['mem_used'], 159 | $save['mem_free'], 160 | $save['mem_buffers'], 161 | $save['swap_total'], 162 | $save['swap_used'], 163 | $save['swap_free'], 164 | $save['swap_cached'], 165 | '"' . base64_encode(json_encode($save['tasks'])) . '"' 166 | ); 167 | 168 | $db->exec('INSERT INTO loads (`' . implode('`,`', $fields) . '`) VALUES(' . implode(',', $values) . ')'); 169 | // stop data loss if maxRemember set to 0 (never delete): 170 | if ($config['maxRemember'] > 0) { 171 | $curr_hour = date("H"); 172 | $curr_minute = date("i"); 173 | $time_window = $config['intervalMinutes']*3; 174 | if (($curr_hour == 0) && ($curr_minute < $time_window)) { 175 | $db->exec('DELETE FROM loads WHERE DATE(created) < "' . date('Y-m-d', strtotime('-' . $config['maxRemember'] . ' days')) . ' "'); 176 | } 177 | /*else { 178 | echo "Skipping a delete task, Hour=".$curr_hour.", Minute=".$curr_minute."\n"; 179 | }*/ 180 | } 181 | -------------------------------------------------------------------------------- /exec/add.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | ##################################################################### 3 | # Load Monitor Plugin for Directadmin (patched version, 2018) # 4 | ##################################################################### 5 | # # 6 | # Patched version: 0.2.9 $ Thu Jul 9 01:01:56 +07 2020 # 7 | # Original version: 0.1 (written by Future Vision) # 8 | # # 9 | ##################################################################### 10 | # Author: # 11 | # # 12 | # - Originally written by: Future Vision # 13 | # - Patched by: Alex S Grebenschikov (www.poralix.com) # 14 | # # 15 | ##################################################################### 16 | 17 | PLUGIN_DIR="/usr/local/directadmin/plugins/load_monitor"; 18 | FILE_RAW=$(mktemp "${PLUGIN_DIR}/data/top.raw.XXXXXX"); 19 | 20 | da_os_major_version() { 21 | /usr/local/directadmin/directadmin o | grep 'Compiled on' | head -n1 | cut -d. -f1 | awk '{print $4}'; 22 | } 23 | 24 | process_top_output() { 25 | LANG="en_US.UTF-8"; 26 | LANGUAGE="en_US.UTF-8"; 27 | LC_ALL="en_US.UTF-8"; 28 | top -n 1 -b > "${FILE_RAW}"; 29 | if [ -f "${FILE_RAW}" ]; then 30 | FILENAME_RAW=$(basename "${FILE_RAW}"); 31 | /usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini -f "${PLUGIN_DIR}/exec/add.php" "${FILENAME_RAW}" "${1}" "${2}"; 32 | rm "${FILE_RAW}"; 33 | exit 0; 34 | else 35 | echo "[ERROR][$(date)] Could not get stats from top output"; 36 | exit 1; 37 | fi; 38 | } 39 | 40 | OS="$(uname)"; 41 | OS_VERSION="$(da_os_major_version)"; 42 | if [ "${OS}" == "FreeBSD" ]; then 43 | echo "[ERROR][$(date)] We don't support FreeBSD yet..."; 44 | exit 1; 45 | elif [ -e "/etc/debian_version" ]; then 46 | # Not tested enought on Debian yet, so it might fail.... 47 | # Use it on your risk 48 | process_top_output "debian" "${OS_VERSION}"; 49 | else 50 | process_top_output "centos" "${OS_VERSION}"; 51 | fi; 52 | 53 | exit 0; 54 | -------------------------------------------------------------------------------- /exec/bootstrap.php: -------------------------------------------------------------------------------- 1 | '00:00 - 03:59', 38 | 2 => '04:00 - 07:59', 39 | 3 => '08:00 - 11:59', 40 | 4 => '12:00 - 15:59', 41 | 5 => '16:00 - 19:59', 42 | 6 => '20:00 - 23:59', 43 | 7 => '00:00 - 23:59' 44 | ); 45 | -------------------------------------------------------------------------------- /exec/clean.php: -------------------------------------------------------------------------------- 1 | exec('DELETE FROM loads'); 20 | -------------------------------------------------------------------------------- /exec/config.ini.default: -------------------------------------------------------------------------------- 1 | maxRemember = 91 2 | maxTasks = 91 3 | intervalMinutes = 1 4 | colorOne = #C42B33 5 | colorFive = #E0F04F 6 | colorFifteen = #4F92F0 -------------------------------------------------------------------------------- /exec/functions.php: -------------------------------------------------------------------------------- 1 | 2 | #include 3 | #include 4 | #include 5 | #include 6 | #include 7 | #define USER "diradmin" 8 | #define GROUP "diradmin" 9 | 10 | int main (int argc, char **argv) 11 | { 12 | int ret; 13 | uid_t ruid, s_ruid; 14 | gid_t rgid, s_rgid; 15 | char name[100]; 16 | struct passwd *pw; 17 | 18 | ruid = getuid(); 19 | rgid = getgid(); 20 | pw = getpwuid(ruid); 21 | 22 | if (ruid == 0) { 23 | printf("[ERROR] You should not run this programm as %s (UID: %d)! Termninating...\n", pw->pw_name, ruid); 24 | return 0; 25 | } 26 | if (strcmp(pw->pw_name, USER) != 0) { 27 | printf("[ERROR] You are not allowed to run this programm as %s (UID: %d)! User %s is expected. Terminating...\n", pw->pw_name, ruid, USER); 28 | return 0; 29 | } 30 | setuid(0); 31 | setgid(0); 32 | 33 | char cmd[] = "/usr/local/directadmin/plugins/load_monitor/scripts/install_cron.sh"; 34 | clearenv(); 35 | execv(cmd, NULL); 36 | } 37 | -------------------------------------------------------------------------------- /exec/parseInputs.php: -------------------------------------------------------------------------------- 1 | $v) 39 | { 40 | unset($process[$key][$k]); 41 | if (is_array($v)) 42 | { 43 | $process[$key][stripslashes($k)] = $v; 44 | $process[] = &$process[$key][stripslashes($k)]; 45 | } 46 | else 47 | { 48 | $process[$key][stripslashes($k)] = stripslashes($v); 49 | } 50 | } 51 | } 52 | unset($process); 53 | } 54 | return true; 55 | } 56 | 57 | parse_input(); 58 | -------------------------------------------------------------------------------- /exec/vacuum.php: -------------------------------------------------------------------------------- 1 | exec('VACUUM;'); 21 | print "VACUUM finished: ". date('r')."\n"; 22 | -------------------------------------------------------------------------------- /hooks/admin_txt.html: -------------------------------------------------------------------------------- 1 | Load Monitor 2 | -------------------------------------------------------------------------------- /load_monitor.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/poralix/load_monitor/b0bb6588a7ff107147e5264f9caa5797da710fbf/load_monitor.png -------------------------------------------------------------------------------- /load_monitor_widget.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/poralix/load_monitor/b0bb6588a7ff107147e5264f9caa5797da710fbf/load_monitor_widget.png -------------------------------------------------------------------------------- /php.ini: -------------------------------------------------------------------------------- 1 | [PHP] 2 | 3 | ;;;;;;;;;;;;;;;;;;; 4 | ; About php.ini ; 5 | ;;;;;;;;;;;;;;;;;;; 6 | ; PHP's initialization file, generally called php.ini, is responsible for 7 | ; configuring many of the aspects of PHP's behavior. 8 | 9 | ; PHP attempts to find and load this configuration from a number of locations. 10 | ; The following is a summary of its search order: 11 | ; 1. SAPI module specific location. 12 | ; 2. The PHPRC environment variable. (As of PHP 5.2.0) 13 | ; 3. A number of predefined registry keys on Windows (As of PHP 5.2.0) 14 | ; 4. Current working directory (except CLI) 15 | ; 5. The web server's directory (for SAPI modules), or directory of PHP 16 | ; (otherwise in Windows) 17 | ; 6. The directory from the --with-config-file-path compile time option, or the 18 | ; Windows directory (C:\windows or C:\winnt) 19 | ; See the PHP docs for more specific information. 20 | ; http://php.net/configuration.file 21 | 22 | ; The syntax of the file is extremely simple. Whitespace and lines 23 | ; beginning with a semicolon are silently ignored (as you probably guessed). 24 | ; Section headers (e.g. [Foo]) are also silently ignored, even though 25 | ; they might mean something in the future. 26 | 27 | ; Directives following the section heading [PATH=/www/mysite] only 28 | ; apply to PHP files in the /www/mysite directory. Directives 29 | ; following the section heading [HOST=www.example.com] only apply to 30 | ; PHP files served from www.example.com. Directives set in these 31 | ; special sections cannot be overridden by user-defined INI files or 32 | ; at runtime. Currently, [PATH=] and [HOST=] sections only work under 33 | ; CGI/FastCGI. 34 | ; http://php.net/ini.sections 35 | 36 | ; Directives are specified using the following syntax: 37 | ; directive = value 38 | ; Directive names are *case sensitive* - foo=bar is different from FOO=bar. 39 | ; Directives are variables used to configure PHP or PHP extensions. 40 | ; There is no name validation. If PHP can't find an expected 41 | ; directive because it is not set or is mistyped, a default value will be used. 42 | 43 | ; The value can be a string, a number, a PHP constant (e.g. E_ALL or M_PI), one 44 | ; of the INI constants (On, Off, True, False, Yes, No and None) or an expression 45 | ; (e.g. E_ALL & ~E_NOTICE), a quoted string ("bar"), or a reference to a 46 | ; previously set variable or directive (e.g. ${foo}) 47 | 48 | ; Expressions in the INI file are limited to bitwise operators and parentheses: 49 | ; | bitwise OR 50 | ; ^ bitwise XOR 51 | ; & bitwise AND 52 | ; ~ bitwise NOT 53 | ; ! boolean NOT 54 | 55 | ; Boolean flags can be turned on using the values 1, On, True or Yes. 56 | ; They can be turned off using the values 0, Off, False or No. 57 | 58 | ; An empty string can be denoted by simply not writing anything after the equal 59 | ; sign, or by using the None keyword: 60 | 61 | ; foo = ; sets foo to an empty string 62 | ; foo = None ; sets foo to an empty string 63 | ; foo = "None" ; sets foo to the string 'None' 64 | 65 | ; If you use constants in your value, and these constants belong to a 66 | ; dynamically loaded extension (either a PHP extension or a Zend extension), 67 | ; you may only use these constants *after* the line that loads the extension. 68 | 69 | ;;;;;;;;;;;;;;;;;;; 70 | ; About this file ; 71 | ;;;;;;;;;;;;;;;;;;; 72 | ; PHP comes packaged with two INI files. One that is recommended to be used 73 | ; in production environments and one that is recommended to be used in 74 | ; development environments. 75 | 76 | ; php.ini-production contains settings which hold security, performance and 77 | ; best practices at its core. But please be aware, these settings may break 78 | ; compatibility with older or less security conscience applications. We 79 | ; recommending using the production ini in production and testing environments. 80 | 81 | ; php.ini-development is very similar to its production variant, except it is 82 | ; much more verbose when it comes to errors. We recommend using the 83 | ; development version only in development environments, as errors shown to 84 | ; application users can inadvertently leak otherwise secure information. 85 | 86 | ; This is php.ini-production INI file. 87 | 88 | ;;;;;;;;;;;;;;;;;;; 89 | ; Quick Reference ; 90 | ;;;;;;;;;;;;;;;;;;; 91 | ; The following are all the settings which are different in either the production 92 | ; or development versions of the INIs with respect to PHP's default behavior. 93 | ; Please see the actual settings later in the document for more details as to why 94 | ; we recommend these changes in PHP's behavior. 95 | 96 | ; display_errors 97 | ; Default Value: On 98 | ; Development Value: On 99 | ; Production Value: Off 100 | 101 | ; display_startup_errors 102 | ; Default Value: Off 103 | ; Development Value: On 104 | ; Production Value: Off 105 | 106 | ; error_reporting 107 | ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED 108 | ; Development Value: E_ALL 109 | ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT 110 | 111 | ; html_errors 112 | ; Default Value: On 113 | ; Development Value: On 114 | ; Production value: On 115 | 116 | ; log_errors 117 | ; Default Value: Off 118 | ; Development Value: On 119 | ; Production Value: On 120 | 121 | ; max_input_time 122 | ; Default Value: -1 (Unlimited) 123 | ; Development Value: 60 (60 seconds) 124 | ; Production Value: 60 (60 seconds) 125 | 126 | ; output_buffering 127 | ; Default Value: Off 128 | ; Development Value: 4096 129 | ; Production Value: 4096 130 | 131 | ; register_argc_argv 132 | ; Default Value: On 133 | ; Development Value: Off 134 | ; Production Value: Off 135 | 136 | ; request_order 137 | ; Default Value: None 138 | ; Development Value: "GP" 139 | ; Production Value: "GP" 140 | 141 | ; session.gc_divisor 142 | ; Default Value: 100 143 | ; Development Value: 1000 144 | ; Production Value: 1000 145 | 146 | ; session.hash_bits_per_character 147 | ; Default Value: 4 148 | ; Development Value: 5 149 | ; Production Value: 5 150 | 151 | ; short_open_tag 152 | ; Default Value: On 153 | ; Development Value: Off 154 | ; Production Value: Off 155 | 156 | ; track_errors 157 | ; Default Value: Off 158 | ; Development Value: On 159 | ; Production Value: Off 160 | 161 | ; url_rewriter.tags 162 | ; Default Value: "a=href,area=href,frame=src,form=,fieldset=" 163 | ; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry" 164 | ; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry" 165 | 166 | ; variables_order 167 | ; Default Value: "EGPCS" 168 | ; Development Value: "GPCS" 169 | ; Production Value: "GPCS" 170 | 171 | ;;;;;;;;;;;;;;;;;;;; 172 | ; php.ini Options ; 173 | ;;;;;;;;;;;;;;;;;;;; 174 | ; Name for user-defined php.ini (.htaccess) files. Default is ".user.ini" 175 | ;user_ini.filename = ".user.ini" 176 | 177 | ; To disable this feature set this option to empty value 178 | ;user_ini.filename = 179 | 180 | ; TTL for user-defined php.ini files (time-to-live) in seconds. Default is 300 seconds (5 minutes) 181 | ;user_ini.cache_ttl = 300 182 | 183 | ;;;;;;;;;;;;;;;;;;;; 184 | ; Language Options ; 185 | ;;;;;;;;;;;;;;;;;;;; 186 | 187 | ; Enable the PHP scripting language engine under Apache. 188 | ; http://php.net/engine 189 | engine = On 190 | 191 | ; This directive determines whether or not PHP will recognize code between 192 | ; tags as PHP source which should be processed as such. It is 193 | ; generally recommended that should be used and that this feature 194 | ; should be disabled, as enabling it may result in issues when generating XML 195 | ; documents, however this remains supported for backward compatibility reasons. 196 | ; Note that this directive does not control the tags. 205 | ; http://php.net/asp-tags 206 | asp_tags = Off 207 | 208 | ; The number of significant digits displayed in floating point numbers. 209 | ; http://php.net/precision 210 | precision = 14 211 | 212 | ; Output buffering is a mechanism for controlling how much output data 213 | ; (excluding headers and cookies) PHP should keep internally before pushing that 214 | ; data to the client. If your application's output exceeds this setting, PHP 215 | ; will send that data in chunks of roughly the size you specify. 216 | ; Turning on this setting and managing its maximum buffer size can yield some 217 | ; interesting side-effects depending on your application and web server. 218 | ; You may be able to send headers and cookies after you've already sent output 219 | ; through print or echo. You also may see performance benefits if your server is 220 | ; emitting less packets due to buffered output versus PHP streaming the output 221 | ; as it gets it. On production servers, 4096 bytes is a good setting for performance 222 | ; reasons. 223 | ; Note: Output buffering can also be controlled via Output Buffering Control 224 | ; functions. 225 | ; Possible Values: 226 | ; On = Enabled and buffer is unlimited. (Use with caution) 227 | ; Off = Disabled 228 | ; Integer = Enables the buffer and sets its maximum size in bytes. 229 | ; Note: This directive is hardcoded to Off for the CLI SAPI 230 | ; Default Value: Off 231 | ; Development Value: 4096 232 | ; Production Value: 4096 233 | ; http://php.net/output-buffering 234 | output_buffering = 4096 235 | 236 | ; You can redirect all of the output of your scripts to a function. For 237 | ; example, if you set output_handler to "mb_output_handler", character 238 | ; encoding will be transparently converted to the specified encoding. 239 | ; Setting any output handler automatically turns on output buffering. 240 | ; Note: People who wrote portable scripts should not depend on this ini 241 | ; directive. Instead, explicitly set the output handler using ob_start(). 242 | ; Using this ini directive may cause problems unless you know what script 243 | ; is doing. 244 | ; Note: You cannot use both "mb_output_handler" with "ob_iconv_handler" 245 | ; and you cannot use both "ob_gzhandler" and "zlib.output_compression". 246 | ; Note: output_handler must be empty if this is set 'On' !!!! 247 | ; Instead you must use zlib.output_handler. 248 | ; http://php.net/output-handler 249 | ;output_handler = 250 | 251 | ; Transparent output compression using the zlib library 252 | ; Valid values for this option are 'off', 'on', or a specific buffer size 253 | ; to be used for compression (default is 4KB) 254 | ; Note: Resulting chunk size may vary due to nature of compression. PHP 255 | ; outputs chunks that are few hundreds bytes each as a result of 256 | ; compression. If you prefer a larger chunk size for better 257 | ; performance, enable output_buffering in addition. 258 | ; Note: You need to use zlib.output_handler instead of the standard 259 | ; output_handler, or otherwise the output will be corrupted. 260 | ; http://php.net/zlib.output-compression 261 | zlib.output_compression = Off 262 | 263 | ; http://php.net/zlib.output-compression-level 264 | ;zlib.output_compression_level = -1 265 | 266 | ; You cannot specify additional output handlers if zlib.output_compression 267 | ; is activated here. This setting does the same as output_handler but in 268 | ; a different order. 269 | ; http://php.net/zlib.output-handler 270 | ;zlib.output_handler = 271 | 272 | ; Implicit flush tells PHP to tell the output layer to flush itself 273 | ; automatically after every output block. This is equivalent to calling the 274 | ; PHP function flush() after each and every call to print() or echo() and each 275 | ; and every HTML block. Turning this option on has serious performance 276 | ; implications and is generally recommended for debugging purposes only. 277 | ; http://php.net/implicit-flush 278 | ; Note: This directive is hardcoded to On for the CLI SAPI 279 | implicit_flush = Off 280 | 281 | ; The unserialize callback function will be called (with the undefined class' 282 | ; name as parameter), if the unserializer finds an undefined class 283 | ; which should be instantiated. A warning appears if the specified function is 284 | ; not defined, or if the function doesn't include/implement the missing class. 285 | ; So only set this entry, if you really want to implement such a 286 | ; callback-function. 287 | unserialize_callback_func = 288 | 289 | ; When floats & doubles are serialized store serialize_precision significant 290 | ; digits after the floating point. The default value ensures that when floats 291 | ; are decoded with unserialize, the data will remain the same. 292 | serialize_precision = 17 293 | 294 | ; open_basedir, if set, limits all file operations to the defined directory 295 | ; and below. This directive makes most sense if used in a per-directory 296 | ; or per-virtualhost web server configuration file. 297 | ; http://php.net/open-basedir 298 | ;open_basedir = 299 | 300 | ; This directive allows you to disable certain functions for security reasons. 301 | ; It receives a comma-delimited list of function names. 302 | ; http://php.net/disable-functions 303 | disable_functions = 304 | 305 | ; This directive allows you to disable certain classes for security reasons. 306 | ; It receives a comma-delimited list of class names. 307 | ; http://php.net/disable-classes 308 | disable_classes = 309 | 310 | ; Colors for Syntax Highlighting mode. Anything that's acceptable in 311 | ; would work. 312 | ; http://php.net/syntax-highlighting 313 | ;highlight.string = #DD0000 314 | ;highlight.comment = #FF9900 315 | ;highlight.keyword = #007700 316 | ;highlight.default = #0000BB 317 | ;highlight.html = #000000 318 | 319 | ; If enabled, the request will be allowed to complete even if the user aborts 320 | ; the request. Consider enabling it if executing long requests, which may end up 321 | ; being interrupted by the user or a browser timing out. PHP's default behavior 322 | ; is to disable this feature. 323 | ; http://php.net/ignore-user-abort 324 | ;ignore_user_abort = On 325 | 326 | ; Determines the size of the realpath cache to be used by PHP. This value should 327 | ; be increased on systems where PHP opens many files to reflect the quantity of 328 | ; the file operations performed. 329 | ; http://php.net/realpath-cache-size 330 | ;realpath_cache_size = 16k 331 | 332 | ; Duration of time, in seconds for which to cache realpath information for a given 333 | ; file or directory. For systems with rarely changing files, consider increasing this 334 | ; value. 335 | ; http://php.net/realpath-cache-ttl 336 | ;realpath_cache_ttl = 120 337 | 338 | ; Enables or disables the circular reference collector. 339 | ; http://php.net/zend.enable-gc 340 | zend.enable_gc = On 341 | 342 | ; If enabled, scripts may be written in encodings that are incompatible with 343 | ; the scanner. CP936, Big5, CP949 and Shift_JIS are the examples of such 344 | ; encodings. To use this feature, mbstring extension must be enabled. 345 | ; Default: Off 346 | ;zend.multibyte = Off 347 | 348 | ; Allows to set the default encoding for the scripts. This value will be used 349 | ; unless "declare(encoding=...)" directive appears at the top of the script. 350 | ; Only affects if zend.multibyte is set. 351 | ; Default: "" 352 | ;zend.script_encoding = 353 | 354 | ;;;;;;;;;;;;;;;;; 355 | ; Miscellaneous ; 356 | ;;;;;;;;;;;;;;;;; 357 | 358 | ; Decides whether PHP may expose the fact that it is installed on the server 359 | ; (e.g. by adding its signature to the Web server header). It is no security 360 | ; threat in any way, but it makes it possible to determine whether you use PHP 361 | ; on your server or not. 362 | ; http://php.net/expose-php 363 | expose_php = Off 364 | 365 | ;;;;;;;;;;;;;;;;;;; 366 | ; Resource Limits ; 367 | ;;;;;;;;;;;;;;;;;;; 368 | 369 | ; Maximum execution time of each script, in seconds 370 | ; http://php.net/max-execution-time 371 | ; Note: This directive is hardcoded to 0 for the CLI SAPI 372 | max_execution_time = 30 373 | 374 | ; Maximum amount of time each script may spend parsing request data. It's a good 375 | ; idea to limit this time on productions servers in order to eliminate unexpectedly 376 | ; long running scripts. 377 | ; Note: This directive is hardcoded to -1 for the CLI SAPI 378 | ; Default Value: -1 (Unlimited) 379 | ; Development Value: 60 (60 seconds) 380 | ; Production Value: 60 (60 seconds) 381 | ; http://php.net/max-input-time 382 | max_input_time = 60 383 | 384 | ; Maximum input variable nesting level 385 | ; http://php.net/max-input-nesting-level 386 | ;max_input_nesting_level = 64 387 | 388 | ; How many GET/POST/COOKIE input variables may be accepted 389 | ; max_input_vars = 1000 390 | 391 | ; Maximum amount of memory a script may consume (128MB) 392 | ; http://php.net/memory-limit 393 | memory_limit = 128M 394 | 395 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 396 | ; Error handling and logging ; 397 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 398 | 399 | ; This directive informs PHP of which errors, warnings and notices you would like 400 | ; it to take action for. The recommended way of setting values for this 401 | ; directive is through the use of the error level constants and bitwise 402 | ; operators. The error level constants are below here for convenience as well as 403 | ; some common settings and their meanings. 404 | ; By default, PHP is set to take action on all errors, notices and warnings EXCEPT 405 | ; those related to E_NOTICE and E_STRICT, which together cover best practices and 406 | ; recommended coding standards in PHP. For performance reasons, this is the 407 | ; recommend error reporting setting. Your production server shouldn't be wasting 408 | ; resources complaining about best practices and coding standards. That's what 409 | ; development servers and development settings are for. 410 | ; Note: The php.ini-development file has this setting as E_ALL. This 411 | ; means it pretty much reports everything which is exactly what you want during 412 | ; development and early testing. 413 | ; 414 | ; Error Level Constants: 415 | ; E_ALL - All errors and warnings (includes E_STRICT as of PHP 5.4.0) 416 | ; E_ERROR - fatal run-time errors 417 | ; E_RECOVERABLE_ERROR - almost fatal run-time errors 418 | ; E_WARNING - run-time warnings (non-fatal errors) 419 | ; E_PARSE - compile-time parse errors 420 | ; E_NOTICE - run-time notices (these are warnings which often result 421 | ; from a bug in your code, but it's possible that it was 422 | ; intentional (e.g., using an uninitialized variable and 423 | ; relying on the fact it is automatically initialized to an 424 | ; empty string) 425 | ; E_STRICT - run-time notices, enable to have PHP suggest changes 426 | ; to your code which will ensure the best interoperability 427 | ; and forward compatibility of your code 428 | ; E_CORE_ERROR - fatal errors that occur during PHP's initial startup 429 | ; E_CORE_WARNING - warnings (non-fatal errors) that occur during PHP's 430 | ; initial startup 431 | ; E_COMPILE_ERROR - fatal compile-time errors 432 | ; E_COMPILE_WARNING - compile-time warnings (non-fatal errors) 433 | ; E_USER_ERROR - user-generated error message 434 | ; E_USER_WARNING - user-generated warning message 435 | ; E_USER_NOTICE - user-generated notice message 436 | ; E_DEPRECATED - warn about code that will not work in future versions 437 | ; of PHP 438 | ; E_USER_DEPRECATED - user-generated deprecation warnings 439 | ; 440 | ; Common Values: 441 | ; E_ALL (Show all errors, warnings and notices including coding standards.) 442 | ; E_ALL & ~E_NOTICE (Show all errors, except for notices) 443 | ; E_ALL & ~E_NOTICE & ~E_STRICT (Show all errors, except for notices and coding standards warnings.) 444 | ; E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR (Show only errors) 445 | ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED 446 | ; Development Value: E_ALL 447 | ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT 448 | ; http://php.net/error-reporting 449 | error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICT 450 | 451 | ; This directive controls whether or not and where PHP will output errors, 452 | ; notices and warnings too. Error output is very useful during development, but 453 | ; it could be very dangerous in production environments. Depending on the code 454 | ; which is triggering the error, sensitive information could potentially leak 455 | ; out of your application such as database usernames and passwords or worse. 456 | ; For production environments, we recommend logging errors rather than 457 | ; sending them to STDOUT. 458 | ; Possible Values: 459 | ; Off = Do not display any errors 460 | ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!) 461 | ; On or stdout = Display errors to STDOUT 462 | ; Default Value: On 463 | ; Development Value: On 464 | ; Production Value: Off 465 | ; http://php.net/display-errors 466 | display_errors = Off 467 | 468 | ; The display of errors which occur during PHP's startup sequence are handled 469 | ; separately from display_errors. PHP's default behavior is to suppress those 470 | ; errors from clients. Turning the display of startup errors on can be useful in 471 | ; debugging configuration problems. We strongly recommend you 472 | ; set this to 'off' for production servers. 473 | ; Default Value: Off 474 | ; Development Value: On 475 | ; Production Value: Off 476 | ; http://php.net/display-startup-errors 477 | display_startup_errors = Off 478 | 479 | ; Besides displaying errors, PHP can also log errors to locations such as a 480 | ; server-specific log, STDERR, or a location specified by the error_log 481 | ; directive found below. While errors should not be displayed on productions 482 | ; servers they should still be monitored and logging is a great way to do that. 483 | ; Default Value: Off 484 | ; Development Value: On 485 | ; Production Value: On 486 | ; http://php.net/log-errors 487 | log_errors = On 488 | 489 | ; Set maximum length of log_errors. In error_log information about the source is 490 | ; added. The default is 1024 and 0 allows to not apply any maximum length at all. 491 | ; http://php.net/log-errors-max-len 492 | log_errors_max_len = 1024 493 | 494 | ; Do not log repeated messages. Repeated errors must occur in same file on same 495 | ; line unless ignore_repeated_source is set true. 496 | ; http://php.net/ignore-repeated-errors 497 | ignore_repeated_errors = Off 498 | 499 | ; Ignore source of message when ignoring repeated messages. When this setting 500 | ; is On you will not log errors with repeated messages from different files or 501 | ; source lines. 502 | ; http://php.net/ignore-repeated-source 503 | ignore_repeated_source = Off 504 | 505 | ; If this parameter is set to Off, then memory leaks will not be shown (on 506 | ; stdout or in the log). This has only effect in a debug compile, and if 507 | ; error reporting includes E_WARNING in the allowed list 508 | ; http://php.net/report-memleaks 509 | report_memleaks = On 510 | 511 | ; This setting is on by default. 512 | ;report_zend_debug = 0 513 | 514 | ; Store the last error/warning message in $php_errormsg (boolean). Setting this value 515 | ; to On can assist in debugging and is appropriate for development servers. It should 516 | ; however be disabled on production servers. 517 | ; Default Value: Off 518 | ; Development Value: On 519 | ; Production Value: Off 520 | ; http://php.net/track-errors 521 | track_errors = Off 522 | 523 | ; Turn off normal error reporting and emit XML-RPC error XML 524 | ; http://php.net/xmlrpc-errors 525 | ;xmlrpc_errors = 0 526 | 527 | ; An XML-RPC faultCode 528 | ;xmlrpc_error_number = 0 529 | 530 | ; When PHP displays or logs an error, it has the capability of formatting the 531 | ; error message as HTML for easier reading. This directive controls whether 532 | ; the error message is formatted as HTML or not. 533 | ; Note: This directive is hardcoded to Off for the CLI SAPI 534 | ; Default Value: On 535 | ; Development Value: On 536 | ; Production value: On 537 | ; http://php.net/html-errors 538 | html_errors = On 539 | 540 | ; If html_errors is set to On *and* docref_root is not empty, then PHP 541 | ; produces clickable error messages that direct to a page describing the error 542 | ; or function causing the error in detail. 543 | ; You can download a copy of the PHP manual from http://php.net/docs 544 | ; and change docref_root to the base URL of your local copy including the 545 | ; leading '/'. You must also specify the file extension being used including 546 | ; the dot. PHP's default behavior is to leave these settings empty, in which 547 | ; case no links to documentation are generated. 548 | ; Note: Never use this feature for production boxes. 549 | ; http://php.net/docref-root 550 | ; Examples 551 | ;docref_root = "/phpmanual/" 552 | 553 | ; http://php.net/docref-ext 554 | ;docref_ext = .html 555 | 556 | ; String to output before an error message. PHP's default behavior is to leave 557 | ; this setting blank. 558 | ; http://php.net/error-prepend-string 559 | ; Example: 560 | ;error_prepend_string = "" 561 | 562 | ; String to output after an error message. PHP's default behavior is to leave 563 | ; this setting blank. 564 | ; http://php.net/error-append-string 565 | ; Example: 566 | ;error_append_string = "" 567 | 568 | ; Log errors to specified file. PHP's default behavior is to leave this value 569 | ; empty. 570 | ; http://php.net/error-log 571 | ; Example: 572 | ;error_log = php_errors.log 573 | ; Log errors to syslog (Event Log on Windows). 574 | ;error_log = syslog 575 | 576 | ;windows.show_crt_warning 577 | ; Default value: 0 578 | ; Development value: 0 579 | ; Production value: 0 580 | 581 | ;;;;;;;;;;;;;;;;; 582 | ; Data Handling ; 583 | ;;;;;;;;;;;;;;;;; 584 | 585 | ; The separator used in PHP generated URLs to separate arguments. 586 | ; PHP's default setting is "&". 587 | ; http://php.net/arg-separator.output 588 | ; Example: 589 | ;arg_separator.output = "&" 590 | 591 | ; List of separator(s) used by PHP to parse input URLs into variables. 592 | ; PHP's default setting is "&". 593 | ; NOTE: Every character in this directive is considered as separator! 594 | ; http://php.net/arg-separator.input 595 | ; Example: 596 | ;arg_separator.input = ";&" 597 | 598 | ; This directive determines which super global arrays are registered when PHP 599 | ; starts up. G,P,C,E & S are abbreviations for the following respective super 600 | ; globals: GET, POST, COOKIE, ENV and SERVER. There is a performance penalty 601 | ; paid for the registration of these arrays and because ENV is not as commonly 602 | ; used as the others, ENV is not recommended on productions servers. You 603 | ; can still get access to the environment variables through getenv() should you 604 | ; need to. 605 | ; Default Value: "EGPCS" 606 | ; Development Value: "GPCS" 607 | ; Production Value: "GPCS"; 608 | ; http://php.net/variables-order 609 | variables_order = "GPCS" 610 | 611 | ; This directive determines which super global data (G,P & C) should be 612 | ; registered into the super global array REQUEST. If so, it also determines 613 | ; the order in which that data is registered. The values for this directive 614 | ; are specified in the same manner as the variables_order directive, 615 | ; EXCEPT one. Leaving this value empty will cause PHP to use the value set 616 | ; in the variables_order directive. It does not mean it will leave the super 617 | ; globals array REQUEST empty. 618 | ; Default Value: None 619 | ; Development Value: "GP" 620 | ; Production Value: "GP" 621 | ; http://php.net/request-order 622 | request_order = "GP" 623 | 624 | ; This directive determines whether PHP registers $argv & $argc each time it 625 | ; runs. $argv contains an array of all the arguments passed to PHP when a script 626 | ; is invoked. $argc contains an integer representing the number of arguments 627 | ; that were passed when the script was invoked. These arrays are extremely 628 | ; useful when running scripts from the command line. When this directive is 629 | ; enabled, registering these variables consumes CPU cycles and memory each time 630 | ; a script is executed. For performance reasons, this feature should be disabled 631 | ; on production servers. 632 | ; Note: This directive is hardcoded to On for the CLI SAPI 633 | ; Default Value: On 634 | ; Development Value: Off 635 | ; Production Value: Off 636 | ; http://php.net/register-argc-argv 637 | register_argc_argv = Off 638 | 639 | ; When enabled, the ENV, REQUEST and SERVER variables are created when they're 640 | ; first used (Just In Time) instead of when the script starts. If these 641 | ; variables are not used within a script, having this directive on will result 642 | ; in a performance gain. The PHP directive register_argc_argv must be disabled 643 | ; for this directive to have any affect. 644 | ; http://php.net/auto-globals-jit 645 | auto_globals_jit = On 646 | 647 | ; Whether PHP will read the POST data. 648 | ; This option is enabled by default. 649 | ; Most likely, you won't want to disable this option globally. It causes $_POST 650 | ; and $_FILES to always be empty; the only way you will be able to read the 651 | ; POST data will be through the php://input stream wrapper. This can be useful 652 | ; to proxy requests or to process the POST data in a memory efficient fashion. 653 | ; http://php.net/enable-post-data-reading 654 | ;enable_post_data_reading = Off 655 | 656 | ; Maximum size of POST data that PHP will accept. 657 | ; Its value may be 0 to disable the limit. It is ignored if POST data reading 658 | ; is disabled through enable_post_data_reading. 659 | ; http://php.net/post-max-size 660 | post_max_size = 64M 661 | 662 | ; Automatically add files before PHP document. 663 | ; http://php.net/auto-prepend-file 664 | auto_prepend_file = 665 | 666 | ; Automatically add files after PHP document. 667 | ; http://php.net/auto-append-file 668 | auto_append_file = 669 | 670 | ; By default, PHP will output a media type using the Content-Type header. To 671 | ; disable this, simply set it to be empty. 672 | ; 673 | ; PHP's built-in default media type is set to text/html. 674 | ; http://php.net/default-mimetype 675 | default_mimetype = "text/html" 676 | 677 | ; PHP's default character set is set to UTF-8. 678 | ; http://php.net/default-charset 679 | default_charset = "UTF-8" 680 | 681 | ; PHP internal character encoding is set to empty. 682 | ; If empty, default_charset is used. 683 | ; http://php.net/internal-encoding 684 | ;internal_encoding = 685 | 686 | ; PHP input character encoding is set to empty. 687 | ; If empty, default_charset is used. 688 | ; http://php.net/input-encoding 689 | ;input_encoding = 690 | 691 | ; PHP output character encoding is set to empty. 692 | ; If empty, default_charset is used. 693 | ; mbstring or iconv output handler is used. 694 | ; See also output_buffer. 695 | ; http://php.net/output-encoding 696 | ;output_encoding = 697 | 698 | ; Always populate the $HTTP_RAW_POST_DATA variable. PHP's default behavior is 699 | ; to disable this feature and it will be removed in a future version. 700 | ; If post reading is disabled through enable_post_data_reading, 701 | ; $HTTP_RAW_POST_DATA is *NOT* populated. 702 | ; http://php.net/always-populate-raw-post-data 703 | ;always_populate_raw_post_data = -1 704 | 705 | ;;;;;;;;;;;;;;;;;;;;;;;;; 706 | ; Paths and Directories ; 707 | ;;;;;;;;;;;;;;;;;;;;;;;;; 708 | 709 | ; UNIX: "/path1:/path2" 710 | ;include_path = ".:/php/includes" 711 | ; 712 | ; Windows: "\path1;\path2" 713 | ;include_path = ".;c:\php\includes" 714 | ; 715 | ; PHP's default setting for include_path is ".;/path/to/php/pear" 716 | ; http://php.net/include-path 717 | 718 | ; The root of the PHP pages, used only if nonempty. 719 | ; if PHP was not compiled with FORCE_REDIRECT, you SHOULD set doc_root 720 | ; if you are running php as a CGI under any web server (other than IIS) 721 | ; see documentation for security issues. The alternate is to use the 722 | ; cgi.force_redirect configuration below 723 | ; http://php.net/doc-root 724 | doc_root = 725 | 726 | ; The directory under which PHP opens the script using /~username used only 727 | ; if nonempty. 728 | ; http://php.net/user-dir 729 | user_dir = 730 | 731 | ; Directory in which the loadable extensions (modules) reside. 732 | ; http://php.net/extension-dir 733 | ; extension_dir = "./" 734 | ; On windows: 735 | ; extension_dir = "ext" 736 | 737 | ; Directory where the temporary files should be placed. 738 | ; Defaults to the system default (see sys_get_temp_dir) 739 | ; sys_temp_dir = "/tmp" 740 | 741 | ; Whether or not to enable the dl() function. The dl() function does NOT work 742 | ; properly in multithreaded servers, such as IIS or Zeus, and is automatically 743 | ; disabled on them. 744 | ; http://php.net/enable-dl 745 | enable_dl = Off 746 | 747 | ; cgi.force_redirect is necessary to provide security running PHP as a CGI under 748 | ; most web servers. Left undefined, PHP turns this on by default. You can 749 | ; turn it off here AT YOUR OWN RISK 750 | ; **You CAN safely turn this off for IIS, in fact, you MUST.** 751 | ; http://php.net/cgi.force-redirect 752 | ;cgi.force_redirect = 1 753 | 754 | ; if cgi.nph is enabled it will force cgi to always sent Status: 200 with 755 | ; every request. PHP's default behavior is to disable this feature. 756 | ;cgi.nph = 1 757 | 758 | ; if cgi.force_redirect is turned on, and you are not running under Apache or Netscape 759 | ; (iPlanet) web servers, you MAY need to set an environment variable name that PHP 760 | ; will look for to know it is OK to continue execution. Setting this variable MAY 761 | ; cause security issues, KNOW WHAT YOU ARE DOING FIRST. 762 | ; http://php.net/cgi.redirect-status-env 763 | ;cgi.redirect_status_env = 764 | 765 | ; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI. PHP's 766 | ; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok 767 | ; what PATH_INFO is. For more information on PATH_INFO, see the cgi specs. Setting 768 | ; this to 1 will cause PHP CGI to fix its paths to conform to the spec. A setting 769 | ; of zero causes PHP to behave as before. Default is 1. You should fix your scripts 770 | ; to use SCRIPT_FILENAME rather than PATH_TRANSLATED. 771 | ; http://php.net/cgi.fix-pathinfo 772 | ;cgi.fix_pathinfo=1 773 | 774 | ; FastCGI under IIS (on WINNT based OS) supports the ability to impersonate 775 | ; security tokens of the calling client. This allows IIS to define the 776 | ; security context that the request runs under. mod_fastcgi under Apache 777 | ; does not currently support this feature (03/17/2002) 778 | ; Set to 1 if running under IIS. Default is zero. 779 | ; http://php.net/fastcgi.impersonate 780 | ;fastcgi.impersonate = 1 781 | 782 | ; Disable logging through FastCGI connection. PHP's default behavior is to enable 783 | ; this feature. 784 | ;fastcgi.logging = 0 785 | 786 | ; cgi.rfc2616_headers configuration option tells PHP what type of headers to 787 | ; use when sending HTTP response code. If set to 0, PHP sends Status: header that 788 | ; is supported by Apache. When this option is set to 1, PHP will send 789 | ; RFC2616 compliant header. 790 | ; Default is zero. 791 | ; http://php.net/cgi.rfc2616-headers 792 | ;cgi.rfc2616_headers = 0 793 | 794 | ;;;;;;;;;;;;;;;; 795 | ; File Uploads ; 796 | ;;;;;;;;;;;;;;;; 797 | 798 | ; Whether to allow HTTP file uploads. 799 | ; http://php.net/file-uploads 800 | file_uploads = On 801 | 802 | ; Temporary directory for HTTP uploaded files (will use system default if not 803 | ; specified). 804 | ; http://php.net/upload-tmp-dir 805 | ;upload_tmp_dir = 806 | 807 | ; Maximum allowed size for uploaded files. 808 | ; http://php.net/upload-max-filesize 809 | upload_max_filesize = 64M 810 | 811 | ; Maximum number of files that can be uploaded via a single request 812 | max_file_uploads = 20 813 | 814 | ;;;;;;;;;;;;;;;;;; 815 | ; Fopen wrappers ; 816 | ;;;;;;;;;;;;;;;;;; 817 | 818 | ; Whether to allow the treatment of URLs (like http:// or ftp://) as files. 819 | ; http://php.net/allow-url-fopen 820 | allow_url_fopen = On 821 | 822 | ; Whether to allow include/require to open URLs (like http:// or ftp://) as files. 823 | ; http://php.net/allow-url-include 824 | allow_url_include = Off 825 | 826 | ; Define the anonymous ftp password (your email address). PHP's default setting 827 | ; for this is empty. 828 | ; http://php.net/from 829 | ;from="john@doe.com" 830 | 831 | ; Define the User-Agent string. PHP's default setting for this is empty. 832 | ; http://php.net/user-agent 833 | ;user_agent="PHP" 834 | 835 | ; Default timeout for socket based streams (seconds) 836 | ; http://php.net/default-socket-timeout 837 | default_socket_timeout = 60 838 | 839 | ; If your scripts have to deal with files from Macintosh systems, 840 | ; or you are running on a Mac and need to deal with files from 841 | ; unix or win32 systems, setting this flag will cause PHP to 842 | ; automatically detect the EOL character in those files so that 843 | ; fgets() and file() will work regardless of the source of the file. 844 | ; http://php.net/auto-detect-line-endings 845 | ;auto_detect_line_endings = Off 846 | 847 | ;;;;;;;;;;;;;;;;;;;;;; 848 | ; Dynamic Extensions ; 849 | ;;;;;;;;;;;;;;;;;;;;;; 850 | 851 | ; If you wish to have an extension loaded automatically, use the following 852 | ; syntax: 853 | ; 854 | ; extension=modulename.extension 855 | ; 856 | ; For example, on Windows: 857 | ; 858 | ; extension=msql.dll 859 | ; 860 | ; ... or under UNIX: 861 | ; 862 | ; extension=msql.so 863 | ; 864 | ; ... or with a path: 865 | ; 866 | ; extension=/path/to/extension/msql.so 867 | ; 868 | ; If you only provide the name of the extension, PHP will look for it in its 869 | ; default extension directory. 870 | ; 871 | ; Windows Extensions 872 | ; Note that ODBC support is built in, so no dll is needed for it. 873 | ; Note that many DLL files are located in the extensions/ (PHP 4) ext/ (PHP 5) 874 | ; extension folders as well as the separate PECL DLL download (PHP 5). 875 | ; Be sure to appropriately set the extension_dir directive. 876 | ; 877 | ;extension=php_bz2.dll 878 | ;extension=php_curl.dll 879 | ;extension=php_fileinfo.dll 880 | ;extension=php_gd2.dll 881 | ;extension=php_gettext.dll 882 | ;extension=php_gmp.dll 883 | ;extension=php_intl.dll 884 | ;extension=php_imap.dll 885 | ;extension=php_interbase.dll 886 | ;extension=php_ldap.dll 887 | ;extension=php_mbstring.dll 888 | ;extension=php_exif.dll ; Must be after mbstring as it depends on it 889 | ;extension=php_mysql.dll 890 | ;extension=php_mysqli.dll 891 | ;extension=php_oci8_12c.dll ; Use with Oracle Database 12c Instant Client 892 | ;extension=php_openssl.dll 893 | ;extension=php_pdo_firebird.dll 894 | ;extension=php_pdo_mysql.dll 895 | ;extension=php_pdo_oci.dll 896 | ;extension=php_pdo_odbc.dll 897 | ;extension=php_pdo_pgsql.dll 898 | ;extension=php_pdo_sqlite.dll 899 | ;extension=php_pgsql.dll 900 | ;extension=php_shmop.dll 901 | 902 | ; The MIBS data available in the PHP distribution must be installed. 903 | ; See http://www.php.net/manual/en/snmp.installation.php 904 | ;extension=php_snmp.dll 905 | 906 | ;extension=php_soap.dll 907 | ;extension=php_sockets.dll 908 | ;extension=php_sqlite3.dll 909 | ;extension=php_sybase_ct.dll 910 | ;extension=php_tidy.dll 911 | ;extension=php_xmlrpc.dll 912 | ;extension=php_xsl.dll 913 | 914 | ;;;;;;;;;;;;;;;;;;; 915 | ; Module Settings ; 916 | ;;;;;;;;;;;;;;;;;;; 917 | 918 | [CLI Server] 919 | ; Whether the CLI web server uses ANSI color coding in its terminal output. 920 | cli_server.color = On 921 | 922 | [Date] 923 | ; Defines the default timezone used by the date functions 924 | ; http://php.net/date.timezone 925 | date.timezone = Asia/Novosibirsk 926 | 927 | ; http://php.net/date.default-latitude 928 | ;date.default_latitude = 31.7667 929 | 930 | ; http://php.net/date.default-longitude 931 | ;date.default_longitude = 35.2333 932 | 933 | ; http://php.net/date.sunrise-zenith 934 | ;date.sunrise_zenith = 90.583333 935 | 936 | ; http://php.net/date.sunset-zenith 937 | ;date.sunset_zenith = 90.583333 938 | 939 | [filter] 940 | ; http://php.net/filter.default 941 | ;filter.default = unsafe_raw 942 | 943 | ; http://php.net/filter.default-flags 944 | ;filter.default_flags = 945 | 946 | [iconv] 947 | ; Use of this INI entry is deprecated, use global input_encoding instead. 948 | ; If empty, default_charset or input_encoding or iconv.input_encoding is used. 949 | ; The precedence is: default_charset < intput_encoding < iconv.input_encoding 950 | ;iconv.input_encoding = 951 | 952 | ; Use of this INI entry is deprecated, use global internal_encoding instead. 953 | ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used. 954 | ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding 955 | ;iconv.internal_encoding = 956 | 957 | ; Use of this INI entry is deprecated, use global output_encoding instead. 958 | ; If empty, default_charset or output_encoding or iconv.output_encoding is used. 959 | ; The precedence is: default_charset < output_encoding < iconv.output_encoding 960 | ; To use an output encoding conversion, iconv's output handler must be set 961 | ; otherwise output encoding conversion cannot be performed. 962 | ;iconv.output_encoding = 963 | 964 | [intl] 965 | ;intl.default_locale = 966 | ; This directive allows you to produce PHP errors when some error 967 | ; happens within intl functions. The value is the level of the error produced. 968 | ; Default is 0, which does not produce any errors. 969 | ;intl.error_level = E_WARNING 970 | 971 | [sqlite3] 972 | ;sqlite3.extension_dir = 973 | 974 | [Pcre] 975 | ;PCRE library backtracking limit. 976 | ; http://php.net/pcre.backtrack-limit 977 | ;pcre.backtrack_limit=100000 978 | 979 | ;PCRE library recursion limit. 980 | ;Please note that if you set this value to a high number you may consume all 981 | ;the available process stack and eventually crash PHP (due to reaching the 982 | ;stack size limit imposed by the Operating System). 983 | ; http://php.net/pcre.recursion-limit 984 | ;pcre.recursion_limit=100000 985 | 986 | [Pdo] 987 | ; Whether to pool ODBC connections. Can be one of "strict", "relaxed" or "off" 988 | ; http://php.net/pdo-odbc.connection-pooling 989 | ;pdo_odbc.connection_pooling=strict 990 | 991 | ;pdo_odbc.db2_instance_name 992 | 993 | [Pdo_mysql] 994 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 995 | ; http://php.net/pdo_mysql.cache_size 996 | pdo_mysql.cache_size = 2000 997 | 998 | ; Default socket name for local MySQL connects. If empty, uses the built-in 999 | ; MySQL defaults. 1000 | ; http://php.net/pdo_mysql.default-socket 1001 | pdo_mysql.default_socket= 1002 | 1003 | [Phar] 1004 | ; http://php.net/phar.readonly 1005 | ;phar.readonly = On 1006 | 1007 | ; http://php.net/phar.require-hash 1008 | ;phar.require_hash = On 1009 | 1010 | ;phar.cache_list = 1011 | 1012 | [mail function] 1013 | ; For Win32 only. 1014 | ; http://php.net/smtp 1015 | SMTP = localhost 1016 | ; http://php.net/smtp-port 1017 | smtp_port = 25 1018 | 1019 | ; For Win32 only. 1020 | ; http://php.net/sendmail-from 1021 | ;sendmail_from = me@example.com 1022 | 1023 | ; For Unix only. You may supply arguments as well (default: "sendmail -t -i"). 1024 | ; http://php.net/sendmail-path 1025 | ;sendmail_path = 1026 | 1027 | ; Force the addition of the specified parameters to be passed as extra parameters 1028 | ; to the sendmail binary. These parameters will always replace the value of 1029 | ; the 5th parameter to mail(). 1030 | ;mail.force_extra_parameters = 1031 | 1032 | ; Add X-PHP-Originating-Script: that will include uid of the script followed by the filename 1033 | ;mail.add_x_header = On 1034 | 1035 | ; The path to a log file that will log all mail() calls. Log entries include 1036 | ; the full path of the script, line number, To address and headers. 1037 | ;mail.log = 1038 | ; Log mail to syslog (Event Log on Windows). 1039 | ;mail.log = syslog 1040 | 1041 | [SQL] 1042 | ; http://php.net/sql.safe-mode 1043 | sql.safe_mode = Off 1044 | 1045 | [ODBC] 1046 | ; http://php.net/odbc.default-db 1047 | ;odbc.default_db = Not yet implemented 1048 | 1049 | ; http://php.net/odbc.default-user 1050 | ;odbc.default_user = Not yet implemented 1051 | 1052 | ; http://php.net/odbc.default-pw 1053 | ;odbc.default_pw = Not yet implemented 1054 | 1055 | ; Controls the ODBC cursor model. 1056 | ; Default: SQL_CURSOR_STATIC (default). 1057 | ;odbc.default_cursortype 1058 | 1059 | ; Allow or prevent persistent links. 1060 | ; http://php.net/odbc.allow-persistent 1061 | odbc.allow_persistent = On 1062 | 1063 | ; Check that a connection is still valid before reuse. 1064 | ; http://php.net/odbc.check-persistent 1065 | odbc.check_persistent = On 1066 | 1067 | ; Maximum number of persistent links. -1 means no limit. 1068 | ; http://php.net/odbc.max-persistent 1069 | odbc.max_persistent = -1 1070 | 1071 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1072 | ; http://php.net/odbc.max-links 1073 | odbc.max_links = -1 1074 | 1075 | ; Handling of LONG fields. Returns number of bytes to variables. 0 means 1076 | ; passthru. 1077 | ; http://php.net/odbc.defaultlrl 1078 | odbc.defaultlrl = 4096 1079 | 1080 | ; Handling of binary data. 0 means passthru, 1 return as is, 2 convert to char. 1081 | ; See the documentation on odbc_binmode and odbc_longreadlen for an explanation 1082 | ; of odbc.defaultlrl and odbc.defaultbinmode 1083 | ; http://php.net/odbc.defaultbinmode 1084 | odbc.defaultbinmode = 1 1085 | 1086 | ;birdstep.max_links = -1 1087 | 1088 | [Interbase] 1089 | ; Allow or prevent persistent links. 1090 | ibase.allow_persistent = 1 1091 | 1092 | ; Maximum number of persistent links. -1 means no limit. 1093 | ibase.max_persistent = -1 1094 | 1095 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1096 | ibase.max_links = -1 1097 | 1098 | ; Default database name for ibase_connect(). 1099 | ;ibase.default_db = 1100 | 1101 | ; Default username for ibase_connect(). 1102 | ;ibase.default_user = 1103 | 1104 | ; Default password for ibase_connect(). 1105 | ;ibase.default_password = 1106 | 1107 | ; Default charset for ibase_connect(). 1108 | ;ibase.default_charset = 1109 | 1110 | ; Default timestamp format. 1111 | ibase.timestampformat = "%Y-%m-%d %H:%M:%S" 1112 | 1113 | ; Default date format. 1114 | ibase.dateformat = "%Y-%m-%d" 1115 | 1116 | ; Default time format. 1117 | ibase.timeformat = "%H:%M:%S" 1118 | 1119 | [MySQL] 1120 | ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements 1121 | ; http://php.net/mysql.allow_local_infile 1122 | mysql.allow_local_infile = On 1123 | 1124 | ; Allow or prevent persistent links. 1125 | ; http://php.net/mysql.allow-persistent 1126 | mysql.allow_persistent = On 1127 | 1128 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 1129 | ; http://php.net/mysql.cache_size 1130 | mysql.cache_size = 2000 1131 | 1132 | ; Maximum number of persistent links. -1 means no limit. 1133 | ; http://php.net/mysql.max-persistent 1134 | mysql.max_persistent = -1 1135 | 1136 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1137 | ; http://php.net/mysql.max-links 1138 | mysql.max_links = -1 1139 | 1140 | ; Default port number for mysql_connect(). If unset, mysql_connect() will use 1141 | ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the 1142 | ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look 1143 | ; at MYSQL_PORT. 1144 | ; http://php.net/mysql.default-port 1145 | mysql.default_port = 1146 | 1147 | ; Default socket name for local MySQL connects. If empty, uses the built-in 1148 | ; MySQL defaults. 1149 | ; http://php.net/mysql.default-socket 1150 | mysql.default_socket = 1151 | 1152 | ; Default host for mysql_connect() (doesn't apply in safe mode). 1153 | ; http://php.net/mysql.default-host 1154 | mysql.default_host = 1155 | 1156 | ; Default user for mysql_connect() (doesn't apply in safe mode). 1157 | ; http://php.net/mysql.default-user 1158 | mysql.default_user = 1159 | 1160 | ; Default password for mysql_connect() (doesn't apply in safe mode). 1161 | ; Note that this is generally a *bad* idea to store passwords in this file. 1162 | ; *Any* user with PHP access can run 'echo get_cfg_var("mysql.default_password") 1163 | ; and reveal this password! And of course, any users with read access to this 1164 | ; file will be able to reveal the password as well. 1165 | ; http://php.net/mysql.default-password 1166 | mysql.default_password = 1167 | 1168 | ; Maximum time (in seconds) for connect timeout. -1 means no limit 1169 | ; http://php.net/mysql.connect-timeout 1170 | mysql.connect_timeout = 60 1171 | 1172 | ; Trace mode. When trace_mode is active (=On), warnings for table/index scans and 1173 | ; SQL-Errors will be displayed. 1174 | ; http://php.net/mysql.trace-mode 1175 | mysql.trace_mode = Off 1176 | 1177 | [MySQLi] 1178 | 1179 | ; Maximum number of persistent links. -1 means no limit. 1180 | ; http://php.net/mysqli.max-persistent 1181 | mysqli.max_persistent = -1 1182 | 1183 | ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements 1184 | ; http://php.net/mysqli.allow_local_infile 1185 | ;mysqli.allow_local_infile = On 1186 | 1187 | ; Allow or prevent persistent links. 1188 | ; http://php.net/mysqli.allow-persistent 1189 | mysqli.allow_persistent = On 1190 | 1191 | ; Maximum number of links. -1 means no limit. 1192 | ; http://php.net/mysqli.max-links 1193 | mysqli.max_links = -1 1194 | 1195 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 1196 | ; http://php.net/mysqli.cache_size 1197 | mysqli.cache_size = 2000 1198 | 1199 | ; Default port number for mysqli_connect(). If unset, mysqli_connect() will use 1200 | ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the 1201 | ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look 1202 | ; at MYSQL_PORT. 1203 | ; http://php.net/mysqli.default-port 1204 | mysqli.default_port = 3306 1205 | 1206 | ; Default socket name for local MySQL connects. If empty, uses the built-in 1207 | ; MySQL defaults. 1208 | ; http://php.net/mysqli.default-socket 1209 | mysqli.default_socket = 1210 | 1211 | ; Default host for mysql_connect() (doesn't apply in safe mode). 1212 | ; http://php.net/mysqli.default-host 1213 | mysqli.default_host = 1214 | 1215 | ; Default user for mysql_connect() (doesn't apply in safe mode). 1216 | ; http://php.net/mysqli.default-user 1217 | mysqli.default_user = 1218 | 1219 | ; Default password for mysqli_connect() (doesn't apply in safe mode). 1220 | ; Note that this is generally a *bad* idea to store passwords in this file. 1221 | ; *Any* user with PHP access can run 'echo get_cfg_var("mysqli.default_pw") 1222 | ; and reveal this password! And of course, any users with read access to this 1223 | ; file will be able to reveal the password as well. 1224 | ; http://php.net/mysqli.default-pw 1225 | mysqli.default_pw = 1226 | 1227 | ; Allow or prevent reconnect 1228 | mysqli.reconnect = Off 1229 | 1230 | [mysqlnd] 1231 | ; Enable / Disable collection of general statistics by mysqlnd which can be 1232 | ; used to tune and monitor MySQL operations. 1233 | ; http://php.net/mysqlnd.collect_statistics 1234 | mysqlnd.collect_statistics = On 1235 | 1236 | ; Enable / Disable collection of memory usage statistics by mysqlnd which can be 1237 | ; used to tune and monitor MySQL operations. 1238 | ; http://php.net/mysqlnd.collect_memory_statistics 1239 | mysqlnd.collect_memory_statistics = Off 1240 | 1241 | ; Size of a pre-allocated buffer used when sending commands to MySQL in bytes. 1242 | ; http://php.net/mysqlnd.net_cmd_buffer_size 1243 | ;mysqlnd.net_cmd_buffer_size = 2048 1244 | 1245 | ; Size of a pre-allocated buffer used for reading data sent by the server in 1246 | ; bytes. 1247 | ; http://php.net/mysqlnd.net_read_buffer_size 1248 | ;mysqlnd.net_read_buffer_size = 32768 1249 | 1250 | [OCI8] 1251 | 1252 | ; Connection: Enables privileged connections using external 1253 | ; credentials (OCI_SYSOPER, OCI_SYSDBA) 1254 | ; http://php.net/oci8.privileged-connect 1255 | ;oci8.privileged_connect = Off 1256 | 1257 | ; Connection: The maximum number of persistent OCI8 connections per 1258 | ; process. Using -1 means no limit. 1259 | ; http://php.net/oci8.max-persistent 1260 | ;oci8.max_persistent = -1 1261 | 1262 | ; Connection: The maximum number of seconds a process is allowed to 1263 | ; maintain an idle persistent connection. Using -1 means idle 1264 | ; persistent connections will be maintained forever. 1265 | ; http://php.net/oci8.persistent-timeout 1266 | ;oci8.persistent_timeout = -1 1267 | 1268 | ; Connection: The number of seconds that must pass before issuing a 1269 | ; ping during oci_pconnect() to check the connection validity. When 1270 | ; set to 0, each oci_pconnect() will cause a ping. Using -1 disables 1271 | ; pings completely. 1272 | ; http://php.net/oci8.ping-interval 1273 | ;oci8.ping_interval = 60 1274 | 1275 | ; Connection: Set this to a user chosen connection class to be used 1276 | ; for all pooled server requests with Oracle 11g Database Resident 1277 | ; Connection Pooling (DRCP). To use DRCP, this value should be set to 1278 | ; the same string for all web servers running the same application, 1279 | ; the database pool must be configured, and the connection string must 1280 | ; specify to use a pooled server. 1281 | ;oci8.connection_class = 1282 | 1283 | ; High Availability: Using On lets PHP receive Fast Application 1284 | ; Notification (FAN) events generated when a database node fails. The 1285 | ; database must also be configured to post FAN events. 1286 | ;oci8.events = Off 1287 | 1288 | ; Tuning: This option enables statement caching, and specifies how 1289 | ; many statements to cache. Using 0 disables statement caching. 1290 | ; http://php.net/oci8.statement-cache-size 1291 | ;oci8.statement_cache_size = 20 1292 | 1293 | ; Tuning: Enables statement prefetching and sets the default number of 1294 | ; rows that will be fetched automatically after statement execution. 1295 | ; http://php.net/oci8.default-prefetch 1296 | ;oci8.default_prefetch = 100 1297 | 1298 | ; Compatibility. Using On means oci_close() will not close 1299 | ; oci_connect() and oci_new_connect() connections. 1300 | ; http://php.net/oci8.old-oci-close-semantics 1301 | ;oci8.old_oci_close_semantics = Off 1302 | 1303 | [PostgreSQL] 1304 | ; Allow or prevent persistent links. 1305 | ; http://php.net/pgsql.allow-persistent 1306 | pgsql.allow_persistent = On 1307 | 1308 | ; Detect broken persistent links always with pg_pconnect(). 1309 | ; Auto reset feature requires a little overheads. 1310 | ; http://php.net/pgsql.auto-reset-persistent 1311 | pgsql.auto_reset_persistent = Off 1312 | 1313 | ; Maximum number of persistent links. -1 means no limit. 1314 | ; http://php.net/pgsql.max-persistent 1315 | pgsql.max_persistent = -1 1316 | 1317 | ; Maximum number of links (persistent+non persistent). -1 means no limit. 1318 | ; http://php.net/pgsql.max-links 1319 | pgsql.max_links = -1 1320 | 1321 | ; Ignore PostgreSQL backends Notice message or not. 1322 | ; Notice message logging require a little overheads. 1323 | ; http://php.net/pgsql.ignore-notice 1324 | pgsql.ignore_notice = 0 1325 | 1326 | ; Log PostgreSQL backends Notice message or not. 1327 | ; Unless pgsql.ignore_notice=0, module cannot log notice message. 1328 | ; http://php.net/pgsql.log-notice 1329 | pgsql.log_notice = 0 1330 | 1331 | [Sybase-CT] 1332 | ; Allow or prevent persistent links. 1333 | ; http://php.net/sybct.allow-persistent 1334 | sybct.allow_persistent = On 1335 | 1336 | ; Maximum number of persistent links. -1 means no limit. 1337 | ; http://php.net/sybct.max-persistent 1338 | sybct.max_persistent = -1 1339 | 1340 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1341 | ; http://php.net/sybct.max-links 1342 | sybct.max_links = -1 1343 | 1344 | ; Minimum server message severity to display. 1345 | ; http://php.net/sybct.min-server-severity 1346 | sybct.min_server_severity = 10 1347 | 1348 | ; Minimum client message severity to display. 1349 | ; http://php.net/sybct.min-client-severity 1350 | sybct.min_client_severity = 10 1351 | 1352 | ; Set per-context timeout 1353 | ; http://php.net/sybct.timeout 1354 | ;sybct.timeout= 1355 | 1356 | ;sybct.packet_size 1357 | 1358 | ; The maximum time in seconds to wait for a connection attempt to succeed before returning failure. 1359 | ; Default: one minute 1360 | ;sybct.login_timeout= 1361 | 1362 | ; The name of the host you claim to be connecting from, for display by sp_who. 1363 | ; Default: none 1364 | ;sybct.hostname= 1365 | 1366 | ; Allows you to define how often deadlocks are to be retried. -1 means "forever". 1367 | ; Default: 0 1368 | ;sybct.deadlock_retry_count= 1369 | 1370 | [bcmath] 1371 | ; Number of decimal digits for all bcmath functions. 1372 | ; http://php.net/bcmath.scale 1373 | bcmath.scale = 0 1374 | 1375 | [browscap] 1376 | ; http://php.net/browscap 1377 | ;browscap = extra/browscap.ini 1378 | 1379 | [Session] 1380 | ; Handler used to store/retrieve data. 1381 | ; http://php.net/session.save-handler 1382 | session.save_handler = files 1383 | 1384 | ; Argument passed to save_handler. In the case of files, this is the path 1385 | ; where data files are stored. Note: Windows users have to change this 1386 | ; variable in order to use PHP's session functions. 1387 | ; 1388 | ; The path can be defined as: 1389 | ; 1390 | ; session.save_path = "N;/path" 1391 | ; 1392 | ; where N is an integer. Instead of storing all the session files in 1393 | ; /path, what this will do is use subdirectories N-levels deep, and 1394 | ; store the session data in those directories. This is useful if 1395 | ; your OS has problems with many files in one directory, and is 1396 | ; a more efficient layout for servers that handle many sessions. 1397 | ; 1398 | ; NOTE 1: PHP will not create this directory structure automatically. 1399 | ; You can use the script in the ext/session dir for that purpose. 1400 | ; NOTE 2: See the section on garbage collection below if you choose to 1401 | ; use subdirectories for session storage 1402 | ; 1403 | ; The file storage module creates files using mode 600 by default. 1404 | ; You can change that by using 1405 | ; 1406 | ; session.save_path = "N;MODE;/path" 1407 | ; 1408 | ; where MODE is the octal representation of the mode. Note that this 1409 | ; does not overwrite the process's umask. 1410 | ; http://php.net/session.save-path 1411 | ;session.save_path = "/tmp" 1412 | 1413 | ; Whether to use strict session mode. 1414 | ; Strict session mode does not accept uninitialized session ID and regenerate 1415 | ; session ID if browser sends uninitialized session ID. Strict mode protects 1416 | ; applications from session fixation via session adoption vulnerability. It is 1417 | ; disabled by default for maximum compatibility, but enabling it is encouraged. 1418 | ; https://wiki.php.net/rfc/strict_sessions 1419 | session.use_strict_mode = 0 1420 | 1421 | ; Whether to use cookies. 1422 | ; http://php.net/session.use-cookies 1423 | session.use_cookies = 1 1424 | 1425 | ; http://php.net/session.cookie-secure 1426 | ;session.cookie_secure = 1427 | 1428 | ; This option forces PHP to fetch and use a cookie for storing and maintaining 1429 | ; the session id. We encourage this operation as it's very helpful in combating 1430 | ; session hijacking when not specifying and managing your own session id. It is 1431 | ; not the be-all and end-all of session hijacking defense, but it's a good start. 1432 | ; http://php.net/session.use-only-cookies 1433 | session.use_only_cookies = 1 1434 | 1435 | ; Name of the session (used as cookie name). 1436 | ; http://php.net/session.name 1437 | session.name = PHPSESSID 1438 | 1439 | ; Initialize session on request startup. 1440 | ; http://php.net/session.auto-start 1441 | session.auto_start = 0 1442 | 1443 | ; Lifetime in seconds of cookie or, if 0, until browser is restarted. 1444 | ; http://php.net/session.cookie-lifetime 1445 | session.cookie_lifetime = 0 1446 | 1447 | ; The path for which the cookie is valid. 1448 | ; http://php.net/session.cookie-path 1449 | session.cookie_path = / 1450 | 1451 | ; The domain for which the cookie is valid. 1452 | ; http://php.net/session.cookie-domain 1453 | session.cookie_domain = 1454 | 1455 | ; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript. 1456 | ; http://php.net/session.cookie-httponly 1457 | session.cookie_httponly = 1458 | 1459 | ; Handler used to serialize data. php is the standard serializer of PHP. 1460 | ; http://php.net/session.serialize-handler 1461 | session.serialize_handler = php 1462 | 1463 | ; Defines the probability that the 'garbage collection' process is started 1464 | ; on every session initialization. The probability is calculated by using 1465 | ; gc_probability/gc_divisor. Where session.gc_probability is the numerator 1466 | ; and gc_divisor is the denominator in the equation. Setting this value to 1 1467 | ; when the session.gc_divisor value is 100 will give you approximately a 1% chance 1468 | ; the gc will run on any give request. 1469 | ; Default Value: 1 1470 | ; Development Value: 1 1471 | ; Production Value: 1 1472 | ; http://php.net/session.gc-probability 1473 | session.gc_probability = 1 1474 | 1475 | ; Defines the probability that the 'garbage collection' process is started on every 1476 | ; session initialization. The probability is calculated by using the following equation: 1477 | ; gc_probability/gc_divisor. Where session.gc_probability is the numerator and 1478 | ; session.gc_divisor is the denominator in the equation. Setting this value to 1 1479 | ; when the session.gc_divisor value is 100 will give you approximately a 1% chance 1480 | ; the gc will run on any give request. Increasing this value to 1000 will give you 1481 | ; a 0.1% chance the gc will run on any give request. For high volume production servers, 1482 | ; this is a more efficient approach. 1483 | ; Default Value: 100 1484 | ; Development Value: 1000 1485 | ; Production Value: 1000 1486 | ; http://php.net/session.gc-divisor 1487 | session.gc_divisor = 1000 1488 | 1489 | ; After this number of seconds, stored data will be seen as 'garbage' and 1490 | ; cleaned up by the garbage collection process. 1491 | ; http://php.net/session.gc-maxlifetime 1492 | session.gc_maxlifetime = 1440 1493 | 1494 | ; NOTE: If you are using the subdirectory option for storing session files 1495 | ; (see session.save_path above), then garbage collection does *not* 1496 | ; happen automatically. You will need to do your own garbage 1497 | ; collection through a shell script, cron entry, or some other method. 1498 | ; For example, the following script would is the equivalent of 1499 | ; setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes): 1500 | ; find /path/to/sessions -cmin +24 -type f | xargs rm 1501 | 1502 | ; Check HTTP Referer to invalidate externally stored URLs containing ids. 1503 | ; HTTP_REFERER has to contain this substring for the session to be 1504 | ; considered as valid. 1505 | ; http://php.net/session.referer-check 1506 | session.referer_check = 1507 | 1508 | ; How many bytes to read from the file. 1509 | ; http://php.net/session.entropy-length 1510 | ;session.entropy_length = 32 1511 | 1512 | ; Specified here to create the session id. 1513 | ; http://php.net/session.entropy-file 1514 | ; Defaults to /dev/urandom 1515 | ; On systems that don't have /dev/urandom but do have /dev/arandom, this will default to /dev/arandom 1516 | ; If neither are found at compile time, the default is no entropy file. 1517 | ; On windows, setting the entropy_length setting will activate the 1518 | ; Windows random source (using the CryptoAPI) 1519 | ;session.entropy_file = /dev/urandom 1520 | 1521 | ; Set to {nocache,private,public,} to determine HTTP caching aspects 1522 | ; or leave this empty to avoid sending anti-caching headers. 1523 | ; http://php.net/session.cache-limiter 1524 | session.cache_limiter = nocache 1525 | 1526 | ; Document expires after n minutes. 1527 | ; http://php.net/session.cache-expire 1528 | session.cache_expire = 180 1529 | 1530 | ; trans sid support is disabled by default. 1531 | ; Use of trans sid may risk your users' security. 1532 | ; Use this option with caution. 1533 | ; - User may send URL contains active session ID 1534 | ; to other person via. email/irc/etc. 1535 | ; - URL that contains active session ID may be stored 1536 | ; in publicly accessible computer. 1537 | ; - User may access your site with the same session ID 1538 | ; always using URL stored in browser's history or bookmarks. 1539 | ; http://php.net/session.use-trans-sid 1540 | session.use_trans_sid = 0 1541 | 1542 | ; Select a hash function for use in generating session ids. 1543 | ; Possible Values 1544 | ; 0 (MD5 128 bits) 1545 | ; 1 (SHA-1 160 bits) 1546 | ; This option may also be set to the name of any hash function supported by 1547 | ; the hash extension. A list of available hashes is returned by the hash_algos() 1548 | ; function. 1549 | ; http://php.net/session.hash-function 1550 | session.hash_function = 0 1551 | 1552 | ; Define how many bits are stored in each character when converting 1553 | ; the binary hash data to something readable. 1554 | ; Possible values: 1555 | ; 4 (4 bits: 0-9, a-f) 1556 | ; 5 (5 bits: 0-9, a-v) 1557 | ; 6 (6 bits: 0-9, a-z, A-Z, "-", ",") 1558 | ; Default Value: 4 1559 | ; Development Value: 5 1560 | ; Production Value: 5 1561 | ; http://php.net/session.hash-bits-per-character 1562 | session.hash_bits_per_character = 5 1563 | 1564 | ; The URL rewriter will look for URLs in a defined set of HTML tags. 1565 | ; form/fieldset are special; if you include them here, the rewriter will 1566 | ; add a hidden field with the info which is otherwise appended 1567 | ; to URLs. If you want XHTML conformity, remove the form entry. 1568 | ; Note that all valid entries require a "=", even if no value follows. 1569 | ; Default Value: "a=href,area=href,frame=src,form=,fieldset=" 1570 | ; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry" 1571 | ; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry" 1572 | ; http://php.net/url-rewriter.tags 1573 | url_rewriter.tags = "a=href,area=href,frame=src,input=src,form=fakeentry" 1574 | 1575 | ; Enable upload progress tracking in $_SESSION 1576 | ; Default Value: On 1577 | ; Development Value: On 1578 | ; Production Value: On 1579 | ; http://php.net/session.upload-progress.enabled 1580 | ;session.upload_progress.enabled = On 1581 | 1582 | ; Cleanup the progress information as soon as all POST data has been read 1583 | ; (i.e. upload completed). 1584 | ; Default Value: On 1585 | ; Development Value: On 1586 | ; Production Value: On 1587 | ; http://php.net/session.upload-progress.cleanup 1588 | ;session.upload_progress.cleanup = On 1589 | 1590 | ; A prefix used for the upload progress key in $_SESSION 1591 | ; Default Value: "upload_progress_" 1592 | ; Development Value: "upload_progress_" 1593 | ; Production Value: "upload_progress_" 1594 | ; http://php.net/session.upload-progress.prefix 1595 | ;session.upload_progress.prefix = "upload_progress_" 1596 | 1597 | ; The index name (concatenated with the prefix) in $_SESSION 1598 | ; containing the upload progress information 1599 | ; Default Value: "PHP_SESSION_UPLOAD_PROGRESS" 1600 | ; Development Value: "PHP_SESSION_UPLOAD_PROGRESS" 1601 | ; Production Value: "PHP_SESSION_UPLOAD_PROGRESS" 1602 | ; http://php.net/session.upload-progress.name 1603 | ;session.upload_progress.name = "PHP_SESSION_UPLOAD_PROGRESS" 1604 | 1605 | ; How frequently the upload progress should be updated. 1606 | ; Given either in percentages (per-file), or in bytes 1607 | ; Default Value: "1%" 1608 | ; Development Value: "1%" 1609 | ; Production Value: "1%" 1610 | ; http://php.net/session.upload-progress.freq 1611 | ;session.upload_progress.freq = "1%" 1612 | 1613 | ; The minimum delay between updates, in seconds 1614 | ; Default Value: 1 1615 | ; Development Value: 1 1616 | ; Production Value: 1 1617 | ; http://php.net/session.upload-progress.min-freq 1618 | ;session.upload_progress.min_freq = "1" 1619 | 1620 | [MSSQL] 1621 | ; Allow or prevent persistent links. 1622 | mssql.allow_persistent = On 1623 | 1624 | ; Maximum number of persistent links. -1 means no limit. 1625 | mssql.max_persistent = -1 1626 | 1627 | ; Maximum number of links (persistent+non persistent). -1 means no limit. 1628 | mssql.max_links = -1 1629 | 1630 | ; Minimum error severity to display. 1631 | mssql.min_error_severity = 10 1632 | 1633 | ; Minimum message severity to display. 1634 | mssql.min_message_severity = 10 1635 | 1636 | ; Compatibility mode with old versions of PHP 3.0. 1637 | mssql.compatibility_mode = Off 1638 | 1639 | ; Connect timeout 1640 | ;mssql.connect_timeout = 5 1641 | 1642 | ; Query timeout 1643 | ;mssql.timeout = 60 1644 | 1645 | ; Valid range 0 - 2147483647. Default = 4096. 1646 | ;mssql.textlimit = 4096 1647 | 1648 | ; Valid range 0 - 2147483647. Default = 4096. 1649 | ;mssql.textsize = 4096 1650 | 1651 | ; Limits the number of records in each batch. 0 = all records in one batch. 1652 | ;mssql.batchsize = 0 1653 | 1654 | ; Specify how datetime and datetim4 columns are returned 1655 | ; On => Returns data converted to SQL server settings 1656 | ; Off => Returns values as YYYY-MM-DD hh:mm:ss 1657 | ;mssql.datetimeconvert = On 1658 | 1659 | ; Use NT authentication when connecting to the server 1660 | mssql.secure_connection = Off 1661 | 1662 | ; Specify max number of processes. -1 = library default 1663 | ; msdlib defaults to 25 1664 | ; FreeTDS defaults to 4096 1665 | ;mssql.max_procs = -1 1666 | 1667 | ; Specify client character set. 1668 | ; If empty or not set the client charset from freetds.conf is used 1669 | ; This is only used when compiled with FreeTDS 1670 | ;mssql.charset = "ISO-8859-1" 1671 | 1672 | [Assertion] 1673 | ; Assert(expr); active by default. 1674 | ; http://php.net/assert.active 1675 | ;assert.active = On 1676 | 1677 | ; Issue a PHP warning for each failed assertion. 1678 | ; http://php.net/assert.warning 1679 | ;assert.warning = On 1680 | 1681 | ; Don't bail out by default. 1682 | ; http://php.net/assert.bail 1683 | ;assert.bail = Off 1684 | 1685 | ; User-function to be called if an assertion fails. 1686 | ; http://php.net/assert.callback 1687 | ;assert.callback = 0 1688 | 1689 | ; Eval the expression with current error_reporting(). Set to true if you want 1690 | ; error_reporting(0) around the eval(). 1691 | ; http://php.net/assert.quiet-eval 1692 | ;assert.quiet_eval = 0 1693 | 1694 | [COM] 1695 | ; path to a file containing GUIDs, IIDs or filenames of files with TypeLibs 1696 | ; http://php.net/com.typelib-file 1697 | ;com.typelib_file = 1698 | 1699 | ; allow Distributed-COM calls 1700 | ; http://php.net/com.allow-dcom 1701 | ;com.allow_dcom = true 1702 | 1703 | ; autoregister constants of a components typlib on com_load() 1704 | ; http://php.net/com.autoregister-typelib 1705 | ;com.autoregister_typelib = true 1706 | 1707 | ; register constants casesensitive 1708 | ; http://php.net/com.autoregister-casesensitive 1709 | ;com.autoregister_casesensitive = false 1710 | 1711 | ; show warnings on duplicate constant registrations 1712 | ; http://php.net/com.autoregister-verbose 1713 | ;com.autoregister_verbose = true 1714 | 1715 | ; The default character set code-page to use when passing strings to and from COM objects. 1716 | ; Default: system ANSI code page 1717 | ;com.code_page= 1718 | 1719 | [mbstring] 1720 | ; language for internal character representation. 1721 | ; This affects mb_send_mail() and mbstrig.detect_order. 1722 | ; http://php.net/mbstring.language 1723 | ;mbstring.language = Japanese 1724 | 1725 | ; Use of this INI entry is deprecated, use global internal_encoding instead. 1726 | ; internal/script encoding. 1727 | ; Some encoding cannot work as internal encoding. (e.g. SJIS, BIG5, ISO-2022-*) 1728 | ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used. 1729 | ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding 1730 | ;mbstring.internal_encoding = 1731 | 1732 | ; Use of this INI entry is deprecated, use global input_encoding instead. 1733 | ; http input encoding. 1734 | ; mbstring.encoding_traslation = On is needed to use this setting. 1735 | ; If empty, default_charset or input_encoding or mbstring.input is used. 1736 | ; The precedence is: default_charset < intput_encoding < mbsting.http_input 1737 | ; http://php.net/mbstring.http-input 1738 | ;mbstring.http_input = 1739 | 1740 | ; Use of this INI entry is deprecated, use global output_encoding instead. 1741 | ; http output encoding. 1742 | ; mb_output_handler must be registered as output buffer to function. 1743 | ; If empty, default_charset or output_encoding or mbstring.http_output is used. 1744 | ; The precedence is: default_charset < output_encoding < mbstring.http_output 1745 | ; To use an output encoding conversion, mbstring's output handler must be set 1746 | ; otherwise output encoding conversion cannot be performed. 1747 | ; http://php.net/mbstring.http-output 1748 | ;mbstring.http_output = 1749 | 1750 | ; enable automatic encoding translation according to 1751 | ; mbstring.internal_encoding setting. Input chars are 1752 | ; converted to internal encoding by setting this to On. 1753 | ; Note: Do _not_ use automatic encoding translation for 1754 | ; portable libs/applications. 1755 | ; http://php.net/mbstring.encoding-translation 1756 | ;mbstring.encoding_translation = Off 1757 | 1758 | ; automatic encoding detection order. 1759 | ; "auto" detect order is changed according to mbstring.language 1760 | ; http://php.net/mbstring.detect-order 1761 | ;mbstring.detect_order = auto 1762 | 1763 | ; substitute_character used when character cannot be converted 1764 | ; one from another 1765 | ; http://php.net/mbstring.substitute-character 1766 | ;mbstring.substitute_character = none 1767 | 1768 | ; overload(replace) single byte functions by mbstring functions. 1769 | ; mail(), ereg(), etc are overloaded by mb_send_mail(), mb_ereg(), 1770 | ; etc. Possible values are 0,1,2,4 or combination of them. 1771 | ; For example, 7 for overload everything. 1772 | ; 0: No overload 1773 | ; 1: Overload mail() function 1774 | ; 2: Overload str*() functions 1775 | ; 4: Overload ereg*() functions 1776 | ; http://php.net/mbstring.func-overload 1777 | ;mbstring.func_overload = 0 1778 | 1779 | ; enable strict encoding detection. 1780 | ; Default: Off 1781 | ;mbstring.strict_detection = On 1782 | 1783 | ; This directive specifies the regex pattern of content types for which mb_output_handler() 1784 | ; is activated. 1785 | ; Default: mbstring.http_output_conv_mimetype=^(text/|application/xhtml\+xml) 1786 | ;mbstring.http_output_conv_mimetype= 1787 | 1788 | [gd] 1789 | ; Tell the jpeg decode to ignore warnings and try to create 1790 | ; a gd image. The warning will then be displayed as notices 1791 | ; disabled by default 1792 | ; http://php.net/gd.jpeg-ignore-warning 1793 | ;gd.jpeg_ignore_warning = 0 1794 | 1795 | [exif] 1796 | ; Exif UNICODE user comments are handled as UCS-2BE/UCS-2LE and JIS as JIS. 1797 | ; With mbstring support this will automatically be converted into the encoding 1798 | ; given by corresponding encode setting. When empty mbstring.internal_encoding 1799 | ; is used. For the decode settings you can distinguish between motorola and 1800 | ; intel byte order. A decode setting cannot be empty. 1801 | ; http://php.net/exif.encode-unicode 1802 | ;exif.encode_unicode = ISO-8859-15 1803 | 1804 | ; http://php.net/exif.decode-unicode-motorola 1805 | ;exif.decode_unicode_motorola = UCS-2BE 1806 | 1807 | ; http://php.net/exif.decode-unicode-intel 1808 | ;exif.decode_unicode_intel = UCS-2LE 1809 | 1810 | ; http://php.net/exif.encode-jis 1811 | ;exif.encode_jis = 1812 | 1813 | ; http://php.net/exif.decode-jis-motorola 1814 | ;exif.decode_jis_motorola = JIS 1815 | 1816 | ; http://php.net/exif.decode-jis-intel 1817 | ;exif.decode_jis_intel = JIS 1818 | 1819 | [Tidy] 1820 | ; The path to a default tidy configuration file to use when using tidy 1821 | ; http://php.net/tidy.default-config 1822 | ;tidy.default_config = /usr/local/lib/php/default.tcfg 1823 | 1824 | ; Should tidy clean and repair output automatically? 1825 | ; WARNING: Do not use this option if you are generating non-html content 1826 | ; such as dynamic images 1827 | ; http://php.net/tidy.clean-output 1828 | tidy.clean_output = Off 1829 | 1830 | [soap] 1831 | ; Enables or disables WSDL caching feature. 1832 | ; http://php.net/soap.wsdl-cache-enabled 1833 | soap.wsdl_cache_enabled=1 1834 | 1835 | ; Sets the directory name where SOAP extension will put cache files. 1836 | ; http://php.net/soap.wsdl-cache-dir 1837 | soap.wsdl_cache_dir="/tmp" 1838 | 1839 | ; (time to live) Sets the number of second while cached file will be used 1840 | ; instead of original one. 1841 | ; http://php.net/soap.wsdl-cache-ttl 1842 | soap.wsdl_cache_ttl=86400 1843 | 1844 | ; Sets the size of the cache limit. (Max. number of WSDL files to cache) 1845 | soap.wsdl_cache_limit = 5 1846 | 1847 | [sysvshm] 1848 | ; A default size of the shared memory segment 1849 | ;sysvshm.init_mem = 10000 1850 | 1851 | [ldap] 1852 | ; Sets the maximum number of open links or -1 for unlimited. 1853 | ldap.max_links = -1 1854 | 1855 | [mcrypt] 1856 | ; For more information about mcrypt settings see http://php.net/mcrypt-module-open 1857 | 1858 | ; Directory where to load mcrypt algorithms 1859 | ; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt) 1860 | ;mcrypt.algorithms_dir= 1861 | 1862 | ; Directory where to load mcrypt modes 1863 | ; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt) 1864 | ;mcrypt.modes_dir= 1865 | 1866 | [dba] 1867 | ;dba.default_handler= 1868 | 1869 | [opcache] 1870 | ; Determines if Zend OPCache is enabled 1871 | ;opcache.enable=0 1872 | 1873 | ; Determines if Zend OPCache is enabled for the CLI version of PHP 1874 | ;opcache.enable_cli=0 1875 | 1876 | ; The OPcache shared memory storage size. 1877 | ;opcache.memory_consumption=64 1878 | 1879 | ; The amount of memory for interned strings in Mbytes. 1880 | ;opcache.interned_strings_buffer=4 1881 | 1882 | ; The maximum number of keys (scripts) in the OPcache hash table. 1883 | ; Only numbers between 200 and 100000 are allowed. 1884 | ;opcache.max_accelerated_files=2000 1885 | 1886 | ; The maximum percentage of "wasted" memory until a restart is scheduled. 1887 | ;opcache.max_wasted_percentage=5 1888 | 1889 | ; When this directive is enabled, the OPcache appends the current working 1890 | ; directory to the script key, thus eliminating possible collisions between 1891 | ; files with the same name (basename). Disabling the directive improves 1892 | ; performance, but may break existing applications. 1893 | ;opcache.use_cwd=1 1894 | 1895 | ; When disabled, you must reset the OPcache manually or restart the 1896 | ; webserver for changes to the filesystem to take effect. 1897 | ;opcache.validate_timestamps=1 1898 | 1899 | ; How often (in seconds) to check file timestamps for changes to the shared 1900 | ; memory storage allocation. ("1" means validate once per second, but only 1901 | ; once per request. "0" means always validate) 1902 | ;opcache.revalidate_freq=2 1903 | 1904 | ; Enables or disables file search in include_path optimization 1905 | ;opcache.revalidate_path=0 1906 | 1907 | ; If disabled, all PHPDoc comments are dropped from the code to reduce the 1908 | ; size of the optimized code. 1909 | ;opcache.save_comments=1 1910 | 1911 | ; If disabled, PHPDoc comments are not loaded from SHM, so "Doc Comments" 1912 | ; may be always stored (save_comments=1), but not loaded by applications 1913 | ; that don't need them anyway. 1914 | ;opcache.load_comments=1 1915 | 1916 | ; If enabled, a fast shutdown sequence is used for the accelerated code 1917 | ;opcache.fast_shutdown=0 1918 | 1919 | ; Allow file existence override (file_exists, etc.) performance feature. 1920 | ;opcache.enable_file_override=0 1921 | 1922 | ; A bitmask, where each bit enables or disables the appropriate OPcache 1923 | ; passes 1924 | ;opcache.optimization_level=0xffffffff 1925 | 1926 | ;opcache.inherited_hack=1 1927 | ;opcache.dups_fix=0 1928 | 1929 | ; The location of the OPcache blacklist file (wildcards allowed). 1930 | ; Each OPcache blacklist file is a text file that holds the names of files 1931 | ; that should not be accelerated. The file format is to add each filename 1932 | ; to a new line. The filename may be a full path or just a file prefix 1933 | ; (i.e., /var/www/x blacklists all the files and directories in /var/www 1934 | ; that start with 'x'). Line starting with a ; are ignored (comments). 1935 | ;opcache.blacklist_filename= 1936 | 1937 | ; Allows exclusion of large files from being cached. By default all files 1938 | ; are cached. 1939 | ;opcache.max_file_size=0 1940 | 1941 | ; Check the cache checksum each N requests. 1942 | ; The default value of "0" means that the checks are disabled. 1943 | ;opcache.consistency_checks=0 1944 | 1945 | ; How long to wait (in seconds) for a scheduled restart to begin if the cache 1946 | ; is not being accessed. 1947 | ;opcache.force_restart_timeout=180 1948 | 1949 | ; OPcache error_log file name. Empty string assumes "stderr". 1950 | ;opcache.error_log= 1951 | 1952 | ; All OPcache errors go to the Web server log. 1953 | ; By default, only fatal errors (level 0) or errors (level 1) are logged. 1954 | ; You can also enable warnings (level 2), info messages (level 3) or 1955 | ; debug messages (level 4). 1956 | ;opcache.log_verbosity_level=1 1957 | 1958 | ; Preferred Shared Memory back-end. Leave empty and let the system decide. 1959 | ;opcache.preferred_memory_model= 1960 | 1961 | ; Protect the shared memory from unexpected writing during script execution. 1962 | ; Useful for internal debugging only. 1963 | ;opcache.protect_memory=0 1964 | 1965 | [curl] 1966 | ; A default value for the CURLOPT_CAINFO option. This is required to be an 1967 | ; absolute path. 1968 | ;curl.cainfo = 1969 | 1970 | [openssl] 1971 | ; The location of a Certificate Authority (CA) file on the local filesystem 1972 | ; to use when verifying the identity of SSL/TLS peers. Most users should 1973 | ; not specify a value for this directive as PHP will attempt to use the 1974 | ; OS-managed cert stores in its absence. If specified, this value may still 1975 | ; be overridden on a per-stream basis via the "cafile" SSL stream context 1976 | ; option. 1977 | ;openssl.cafile= 1978 | 1979 | ; If openssl.cafile is not specified or if the CA file is not found, the 1980 | ; directory pointed to by openssl.capath is searched for a suitable 1981 | ; certificate. This value must be a correctly hashed certificate directory. 1982 | ; Most users should not specify a value for this directive as PHP will 1983 | ; attempt to use the OS-managed cert stores in its absence. If specified, 1984 | ; this value may still be overridden on a per-stream basis via the "capath" 1985 | ; SSL stream context option. 1986 | ;openssl.capath= 1987 | 1988 | ; Local Variables: 1989 | ; tab-width: 4 1990 | ; End: 1991 | mail.add_x_header = On 1992 | -------------------------------------------------------------------------------- /plugin.conf: -------------------------------------------------------------------------------- 1 | active=yes 2 | author=Future Vision (patched by Poralix.com) 3 | id=load_monitor 4 | installed=yes 5 | name=Load Monitor 6 | update_url=https://files.poralix.com/get/freesoftware/load_monitor 7 | version_url=https://files.poralix.com/version/freesoftware/load_monitor 8 | version=0.2.9 9 | admin_run_as=diradmin 10 | admin_widgets=WGT_PLUGINS_ADMIN_LOAD_MONITOR 11 | admin_widgets_default=WGT_PLUGINS_ADMIN_LOAD_MONITOR 12 | refresh_interval=120:WGT_PLUGINS_ADMIN_LOAD_MONITOR 13 | -------------------------------------------------------------------------------- /scripts/install.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | ##################################################################### 3 | # Load Monitor Plugin for Directadmin (patched version, 2018) # 4 | ##################################################################### 5 | # # 6 | # Patched version: 0.2.9 $ Thu Jul 9 01:01:56 +07 2020 # 7 | # Original version: 0.1 (written by Future Vision) # 8 | # # 9 | ##################################################################### 10 | # Author: # 11 | # # 12 | # - Originally written by: Future Vision # 13 | # - Patched by: Alex S Grebenschikov (www.poralix.com) # 14 | # # 15 | ##################################################################### 16 | 17 | PLUGIN_DIR="/usr/local/directadmin/plugins/load_monitor"; 18 | PHP_INI="${PLUGIN_DIR}/php.ini"; 19 | 20 | # permissions 21 | chown -R diradmin:diradmin "${PLUGIN_DIR}"; 22 | chmod 755 "${PLUGIN_DIR}"; 23 | chmod 755 ${PLUGIN_DIR}/admin/*.html; 24 | chmod 755 ${PLUGIN_DIR}/exec/*.sh; 25 | 26 | # config 27 | CUSTOM_CONFIG="${PLUGIN_DIR}/exec/config.ini"; 28 | DEFAULT_CONFIG="${PLUGIN_DIR}/exec/config.ini.default"; 29 | [ -e "${CUSTOM_CONFIG}" ] || cp -p "${DEFAULT_CONFIG}" "${CUSTOM_CONFIG}"; 30 | chown diradmin:diradmin "${CUSTOM_CONFIG}"; 31 | chmod 644 "${CUSTOM_CONFIG}"; 32 | 33 | # php.ini 34 | TZ=$(grep ^php_timezone= /usr/local/directadmin/custombuild/options.conf | cut -d= -f2); 35 | perl -pi -e "s#^date.timezone = .*#date.timezone = ${TZ}#" ${PHP_INI}; 36 | 37 | # sqlite 38 | [ -f "${PLUGIN_DIR}/data/load_monitor.sqlite" ] || ${PLUGIN_DIR}/scripts/install_db.sh; 39 | ${PLUGIN_DIR}/scripts/install_cron.sh; 40 | 41 | # wrapper 42 | GCC=gcc; 43 | if [ -e /usr/bin/gcc ]; then 44 | GCC=/usr/bin/gcc; 45 | elif [ -e /usr/local/bin/gcc ]; then 46 | GCC=/usr/local/bin/gcc; 47 | elif [ -e /bin/gcc ]; then 48 | GCC=/bin/gcc; 49 | fi; 50 | 51 | WRAPPER="install-cron"; 52 | ${GCC} -std=gnu99 -B/usr/bin -o ${PLUGIN_DIR}/exec/${WRAPPER} ${PLUGIN_DIR}/exec/${WRAPPER}.c >> /dev/null 2>&1; 53 | chown root:diradmin ${PLUGIN_DIR}/exec/${WRAPPER}; 54 | chmod 4550 ${PLUGIN_DIR}/exec/${WRAPPER}; 55 | 56 | # plugin's configs 57 | cd "${PLUGIN_DIR}"; 58 | perl -pi -e "s/^installed=.*/installed=yes/" plugin.conf; 59 | perl -pi -e "s/^active=.*/active=yes/" plugin.conf; 60 | 61 | echo "Plugin installed..."; 62 | 63 | exit 0; 64 | -------------------------------------------------------------------------------- /scripts/install_cron.php: -------------------------------------------------------------------------------- 1 | ${PLUGIN_DIR}/cron_current; 20 | /usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini -f ${PLUGIN_DIR}/scripts/install_cron.php; 21 | crontab ${PLUGIN_DIR}/cron_new; 22 | rm ${PLUGIN_DIR}/cron_current; 23 | rm ${PLUGIN_DIR}/cron_new; 24 | exit 0; 25 | -------------------------------------------------------------------------------- /scripts/install_db.php: -------------------------------------------------------------------------------- 1 | exec("CREATE TABLE loads ( 26 | created TEXT PRIMARY KEY, 27 | uptime TEXT, 28 | users INTEGER, 29 | one REAL, 30 | five REAL, 31 | fifteen REAL, 32 | task_total INTEGER, 33 | task_running INTEGER, 34 | task_sleeping INTEGER, 35 | task_stopped INTEGER, 36 | task_zombie INTEGER, 37 | cpu_us REAL, 38 | cpu_sy REAL, 39 | cpu_ni REAL, 40 | cpu_id REAL, 41 | cpu_wa REAL, 42 | cpu_hi REAL, 43 | cpu_si REAL, 44 | cpu_st REAL, 45 | mem_total INTEGER, 46 | mem_used INTEGER, 47 | mem_free INTEGER, 48 | mem_buffers INTEGER, 49 | swap_total INTEGER, 50 | swap_used INTEGER, 51 | swap_free INTEGER, 52 | swap_cached INTEGER, 53 | tasks BLOB 54 | )"); 55 | -------------------------------------------------------------------------------- /scripts/install_db.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | ##################################################################### 3 | # Load Monitor Plugin for Directadmin (patched version, 2018) # 4 | ##################################################################### 5 | # # 6 | # Patched version: 0.2.9 $ Thu Jul 9 01:01:56 +07 2020 # 7 | # Original version: 0.1 (written by Future Vision) # 8 | # # 9 | ##################################################################### 10 | # Author: # 11 | # # 12 | # - Originally written by: Future Vision # 13 | # - Patched by: Alex S Grebenschikov (www.poralix.com) # 14 | # # 15 | ##################################################################### 16 | 17 | PLUGIN_DIR="/usr/local/directadmin/plugins/load_monitor"; 18 | /usr/local/bin/php -nc/usr/local/directadmin/plugins/load_monitor/php.ini -f ${PLUGIN_DIR}/scripts/install_db.php; 19 | exit 0; 20 | -------------------------------------------------------------------------------- /scripts/uninstall.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | ##################################################################### 3 | # Load Monitor Plugin for Directadmin (patched version, 2018) # 4 | ##################################################################### 5 | # # 6 | # Patched version: 0.2.9 $ Thu Jul 9 01:01:56 +07 2020 # 7 | # Original version: 0.1 (written by Future Vision) # 8 | # # 9 | ##################################################################### 10 | # Author: # 11 | # # 12 | # - Originally written by: Future Vision # 13 | # - Patched by: Alex S Grebenschikov (www.poralix.com) # 14 | # # 15 | ##################################################################### 16 | 17 | PLUGIN_DIR="/usr/local/directadmin/plugins/load_monitor"; 18 | 19 | [ -f "${PLUGIN_DIR}/data/load_monitor.sqlite" ] && rm -f "${PLUGIN_DIR}/data/load_monitor.sqlite"; 20 | 21 | crontab -l | grep -v ${PLUGIN_DIR} > ${PLUGIN_DIR}/cron_new; 22 | crontab ${PLUGIN_DIR}/cron_new; 23 | rm -f ${PLUGIN_DIR}/cron_new; 24 | 25 | cd "${PLUGIN_DIR}"; 26 | perl -pi -e "s/^installed=yes/installed=no/" ./plugin.conf; 27 | perl -pi -e "s/^active=yes/active=no/" ./plugin.conf; 28 | echo "Plugin uninstalled..."; 29 | 30 | exit 0; 31 | -------------------------------------------------------------------------------- /scripts/update.sh: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | ##################################################################### 3 | # Load Monitor Plugin for Directadmin (patched version, 2018) # 4 | ##################################################################### 5 | # # 6 | # Patched version: 0.2.9 $ Thu Jul 9 01:01:56 +07 2020 # 7 | # Original version: 0.1 (written by Future Vision) # 8 | # # 9 | ##################################################################### 10 | # Author: # 11 | # # 12 | # - Originally written by: Future Vision # 13 | # - Patched by: Alex S Grebenschikov (www.poralix.com) # 14 | # # 15 | ##################################################################### 16 | 17 | PLUGIN_DIR="/usr/local/directadmin/plugins/load_monitor"; 18 | cd "${PLUGIN_DIR}"; 19 | ./scripts/install.sh >/dev/null 2>&1; 20 | 21 | echo "Plugin updated..."; 22 | 23 | exit 0; 24 | -------------------------------------------------------------------------------- /version.txt: -------------------------------------------------------------------------------- 1 | 0.2.9 --------------------------------------------------------------------------------