1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222 2223 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350 2351 2352 2353 2354 2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368 2369 2370 2371 2372 2373 2374 2375 2376 2377 2378 2379 2380 2381 2382 2383 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412 2413 2414 2415 2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486 2487 2488 2489 2490 2491 2492 2493 2494 2495 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511 2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 2528 2529 2530 2531 2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 2608 2609 2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 2671 2672 2673 2674 2675 2676 2677 2678 2679 2680 2681 2682 2683 2684 2685 2686 2687 2688 2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 2768 2769 2770 2771 2772 2773 2774 2775 2776 2777 2778 2779 2780 2781 2782 2783 2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 2800 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829 2830 2831 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 2912 2913 2914 2915 2916 2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978 2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 2992 2993 2994 2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 3024 3025 3026 3027 3028 3029 3030 3031 3032 3033 3034 3035 3036 3037 3038 3039 3040 3041 3042 3043 3044 3045 3046 3047 3048 3049 3050 3051 3052 3053 3054 3055 3056 3057 3058 3059 3060 3061 3062 3063 3064 3065 3066 3067 3068 3069 3070 3071 3072 3073 3074 3075 3076 3077 3078 3079 3080 3081 3082 3083 3084 3085 3086 3087 3088 3089 3090 3091 3092 3093 3094 3095 3096 3097 3098 3099 3100 3101 3102 3103 3104 3105 3106 3107 3108 3109 3110 3111 3112 3113 3114 3115 3116 3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144 3145 3146 3147 3148 3149 3150 3151 3152 3153 3154 3155 3156 3157 3158 3159 3160 3161 3162 3163 3164 3165 3166 3167 3168 3169 3170 3171 3172 3173 3174 3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 3186 3187 3188 3189 3190 3191 3192 3193 3194 3195 3196 3197 3198 3199 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226 3227 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275 3276 3277 3278 3279 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302 3303 3304 3305 3306 3307 3308 3309 3310 3311 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 3327 3328 3329 3330 3331 3332 3333 3334 3335 3336 3337 3338 3339 3340 3341 3342 3343 3344 3345 3346 3347 3348 3349 3350 3351 3352 3353 3354 3355 3356 3357 3358 3359 3360 3361 3362 3363 3364 3365 3366 3367 3368 3369 3370 3371 3372 3373 3374 3375 3376 3377 3378 3379 3380 3381 3382 3383 3384 3385 3386 3387 3388 3389 3390 3391 3392 3393 3394 3395 3396 3397 3398 3399 3400 3401 3402 3403 3404 3405 3406 3407 3408 3409 3410 3411 3412 3413 3414 3415 3416 3417 3418 3419 3420 3421 3422 3423 3424 3425 3426 3427 3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439 3440 3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454 3455 3456 3457 3458 3459 3460 3461 3462 3463 3464 3465 3466 3467 3468 3469 3470 3471 3472 3473 3474 3475 3476 3477 3478 3479 3480 3481 3482 3483 3484 3485 3486 3487 3488 3489 3490 3491 3492 3493 3494 3495 3496 3497 3498 3499 3500 3501 3502 3503 3504 3505 3506 3507 3508 3509 3510 3511 3512 3513 3514 3515 3516 3517 3518 3519 3520 3521 3522 3523 3524 3525 3526 3527 3528 3529 3530 3531 3532 3533 3534 3535 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598 3599 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611 3612 3613 3614 3615 3616 3617 3618 3619 3620 3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 3631 3632 3633 3634 3635 3636 3637 3638 3639 3640 3641 3642 3643 3644 3645 3646 3647 3648 3649 3650 3651 3652 3653 3654 3655 3656 3657 3658 3659 3660 3661 3662 3663 3664 3665 3666 3667 3668 3669 3670 3671 3672 3673 3674 3675 3676 3677 3678 3679 3680 3681 3682 3683 3684 3685 3686 3687 3688 3689 3690 3691 3692 3693 3694 3695 3696 3697 3698 3699 3700 3701 3702 3703 3704 3705 3706 3707 3708 3709 3710 3711 3712 3713 3714 3715 3716 3717 3718 3719 3720 3721 3722 3723 3724 3725 3726 3727 3728 3729 3730 3731 3732 3733 3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 3744 3745 3746 3747 3748 3749 3750 3751 3752 3753 3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775 3776 3777 3778 3779 3780 3781 3782 3783 3784 3785 3786 3787 3788 3789 3790 3791 3792 3793 3794 3795 3796 3797 3798 3799 3800 3801 3802 3803 3804 3805 3806 3807 3808 3809 3810 3811 3812 3813 3814 3815 3816 3817 3818 3819 3820 3821 3822 3823 3824 3825 3826 3827 3828 3829 3830 3831 3832 3833 3834 3835 3836 3837 3838 3839 3840 3841 3842 3843 3844 3845 3846 3847 3848 3849 3850 3851 3852 3853 3854 3855 3856 3857 3858 3859 3860 3861 3862 3863 3864 3865 3866 3867 3868 3869 3870 3871 3872 3873 3874 3875 3876 3877 3878 3879 3880 3881 3882 3883 3884 3885 3886 3887 3888 3889 3890 3891 3892 3893 3894 3895 3896 3897 3898 3899 3900 3901 3902 3903 3904 3905 3906 3907 3908 3909 3910 3911 3912 3913 3914 3915 3916 3917 3918 3919 3920 3921 3922 3923 3924 3925 3926 3927 3928 3929 3930 3931 3932 3933 3934 3935 3936 3937 3938 3939 3940 3941 3942 3943 3944 3945 3946 3947 3948 3949 3950 3951 3952 3953 3954 3955 3956 3957 3958 3959 3960 3961 3962 3963 3964 3965 3966 3967 3968 3969 3970 3971 3972 3973 3974 3975 3976 3977 3978 3979 3980 3981 3982 3983 3984 3985 3986 3987 3988 3989 3990 3991 3992 3993 3994 3995 3996 3997 3998 3999 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014 4015 4016 4017 4018 4019 4020 4021 4022 4023 4024 4025 4026 4027 4028 4029 4030 4031 4032 4033 4034 4035 4036 4037 4038 4039 4040 4041 4042 4043 4044 4045 4046 4047 4048 4049 4050 4051 4052 4053 4054 4055 4056 4057 4058 4059 4060 4061 4062 4063 4064 4065 4066 4067 4068 4069 4070 4071 4072 4073 4074 4075 4076 4077 4078 4079 4080 4081 4082 4083 4084 4085 4086 4087 4088 4089 4090 4091 4092 4093 4094 4095 4096 4097 4098 4099 4100 4101 4102 4103 4104 4105 4106 4107 4108 4109 4110 4111 4112 4113 4114 4115 4116 4117 4118 4119 4120 4121 4122 4123 4124 4125 4126 4127 4128 4129 4130 4131 4132 4133 4134 4135 4136 4137 4138 4139 4140 4141 4142 4143 4144 4145 4146 4147 4148 4149 4150 4151 4152 4153 4154 4155 4156 4157 4158 4159 4160 4161 4162 4163 4164 4165 4166 4167 4168 4169 4170 4171 4172 4173 4174 4175 4176 4177 4178 4179 4180 4181 4182 4183 4184 4185 4186 4187 4188 4189 4190 4191 4192 4193 4194 4195 4196 4197 4198 4199 4200 4201 4202 4203 4204 4205 4206 4207 4208 4209 4210 4211 4212 4213 4214 4215 4216 4217 4218 4219 4220 4221 4222 4223 4224 4225 4226 4227 4228 4229 4230 4231 4232 4233 4234 4235 4236 4237 4238 4239 4240 4241 4242 4243 4244 4245 4246 4247 4248 4249 4250 4251 4252 4253 4254 4255 4256 4257 4258 4259 4260 4261 4262 4263 4264 4265 4266 4267 4268 4269 4270 4271 4272 4273 4274 4275 4276 4277 4278 4279 4280 4281 4282 4283 4284 4285 4286 4287 4288 4289 4290 4291 4292 4293 4294 4295 4296 4297 4298 4299 4300 4301 4302 4303 4304 4305 4306 4307 4308 4309 4310 4311 4312 4313 4314 4315 4316 4317 4318 4319 4320 4321 4322 4323 4324 4325 4326 4327 4328 4329 4330 4331 4332 4333 4334 4335 4336 4337 4338 4339 4340 4341 4342 4343 4344 4345 4346 4347 4348 4349 4350 4351 4352 4353 4354 4355 4356 4357 4358 4359 4360 4361 4362 4363 4364 4365 4366 4367 4368 4369 4370 4371 4372 4373 4374 4375 4376 4377 4378 4379 4380 4381 4382 4383 4384 4385 4386 4387 4388 4389 4390 4391 4392 4393 4394 4395 4396 4397 4398 4399 4400 4401 4402 4403 4404 4405 4406 4407 4408 4409 4410 4411 4412 4413 4414 4415 4416 4417 4418 4419 4420 4421 4422 4423 4424 4425 4426 4427 4428 4429 4430 4431 4432 4433 4434 4435 4436 4437 4438 4439 4440 4441 4442 4443 4444 4445 4446 4447 4448 4449 4450 4451 4452 4453 4454 4455 4456 4457 4458 4459 4460 4461 4462 4463 4464 4465 4466 4467 4468 4469 4470 4471 4472 4473 4474 4475 4476 4477 4478 4479 4480 4481 4482 4483 4484 4485 4486 4487 4488 4489 4490 4491 4492 4493 4494 4495 4496 4497 4498 4499 4500 4501 4502 4503 4504 4505 4506 4507 4508 4509 4510 4511 4512 4513 4514 4515 4516 4517 4518 4519 4520 4521 4522 4523 4524 4525 4526 4527 4528 4529 4530 4531 4532 4533 4534 4535 4536 4537 4538 4539 4540 4541 4542 4543 4544 4545 4546 4547 4548 4549 4550 4551 4552 4553 4554 4555 4556 4557 4558 4559 4560 4561 4562 4563 4564 4565 4566 4567 4568 4569 4570 4571 4572 4573 4574 4575 4576 4577 4578 4579 4580 4581 4582 4583 4584 4585 4586 4587 4588 4589 4590 4591 4592 4593 4594 4595 4596 4597 4598 4599 4600 4601 4602 4603 4604 4605 4606 4607 4608 4609 4610 4611 4612 4613 4614 4615 4616 4617 4618 4619 4620 4621 4622 4623 4624 4625 4626 4627 4628 4629 4630 4631 4632 4633 4634 4635 4636 4637 4638 4639 4640 4641 4642 4643 4644 4645 4646 4647 4648 4649 4650 4651 4652 4653 4654 4655 4656 4657 4658 4659 4660 4661 4662 4663 4664 4665 4666 4667 4668 4669 4670 4671 4672 4673 4674 4675 4676 4677 4678 4679 4680 4681 4682 4683 4684 4685 4686 4687 4688 4689 4690 4691 4692 4693 4694 4695 4696 4697 4698 4699 4700 4701 4702 4703 4704 4705 4706 4707 4708 4709 4710 4711 4712 4713 4714 4715 4716 4717 4718 4719 4720 4721 4722 4723 4724 4725 4726 4727 4728 4729 4730 4731 4732 4733 4734 4735 4736 4737 4738 4739 4740 4741 4742 4743 4744 4745 4746 4747 4748 4749 4750 4751 4752 4753 4754 4755 4756 4757 4758 4759 4760 4761 4762 4763 4764 4765 4766 4767 4768 4769 4770 4771 4772 4773 4774 4775 4776 4777 4778 4779 4780 4781 4782 4783 4784 4785 4786 4787 4788 4789 4790 4791 4792 4793 4794 4795 4796 4797 4798 4799 4800 4801 4802 4803 4804 4805 4806 4807 4808 4809 4810 4811 4812 4813 4814 4815 4816 4817 4818 4819 4820 4821 4822 4823 4824 4825 4826 4827 4828 4829 4830 4831 4832 4833 4834 4835 4836 4837 4838 4839 4840 4841 4842 4843 4844 4845 4846 4847 4848 4849 4850 4851 4852 4853 4854 4855 4856 4857 4858 4859 4860 4861 4862 4863 4864 4865 4866 4867 4868 4869 4870 4871 4872 4873 4874 4875 4876 4877 4878 4879 4880 4881 4882 4883 4884 4885 4886 4887 4888 4889 4890 4891 4892 4893 4894 4895 4896 4897 4898 4899 4900 4901 4902 4903 4904 4905 4906 4907 4908 4909 4910 4911 4912 4913 4914 4915 4916 4917 4918 4919 4920 4921 4922 4923 4924 4925 4926 4927 4928 4929 4930 4931 4932 4933 4934 4935 4936 4937 4938 4939 4940 4941 4942 4943 4944 4945 4946 4947 4948 4949 4950 4951 4952 4953 4954 4955 4956 4957 4958 4959 4960 4961 4962 4963 4964 4965 4966 4967 4968 4969 4970 4971 4972 4973 4974 4975 4976 4977 4978 4979 4980 4981 4982 4983 4984 4985 4986 4987 4988 4989 4990 4991 4992 4993 4994 4995 4996 4997 4998 4999 5000 5001 5002 5003 5004 5005 5006 5007 5008 5009 5010 5011 5012 5013 5014 5015 5016 5017 5018 5019 5020 5021 5022 5023 5024 5025 5026 5027 5028 5029 5030 5031 5032 5033 5034 5035 5036 5037 5038 5039 5040 5041 5042 5043 5044 5045 5046 5047 5048 5049 5050 5051 5052 5053 5054 5055 5056 5057 5058 5059 5060 5061 5062 5063 5064 5065 5066 5067 5068 5069 5070 5071 5072 5073 5074 5075 5076 5077 5078 5079 5080 5081 5082 5083 5084 5085 5086 5087 5088 5089 5090 5091 5092 5093 5094 5095 5096 5097 5098 5099 5100 5101 5102 5103 5104 5105 5106 5107 5108 5109 5110 5111 5112 5113 5114 5115 5116 5117 5118 5119 5120 5121 5122 5123 5124 5125 5126 5127 5128 5129 5130 5131 5132 5133 5134 5135 5136 5137 5138 5139 5140 5141 5142 5143 5144 5145 5146 5147 5148 5149 5150 5151 5152 5153 5154 5155 5156 5157 5158 5159 5160 5161 5162 5163 5164 5165 5166 5167 5168 5169 5170 5171 5172 5173 5174 5175 5176 5177 5178 5179 5180 5181 5182 5183 5184 5185 5186 5187 5188 5189 5190 5191 5192 5193 5194 5195 5196 5197 5198 5199 5200 5201 5202 5203 5204 5205 5206 5207 5208 5209 5210 5211 5212 5213 5214 5215 5216 5217 5218 5219 5220 5221 5222 5223 5224 5225 5226 5227 5228 5229 5230 5231 5232 5233 5234 5235 5236 5237 5238 5239 5240 5241 5242 5243 5244 5245 5246 5247 5248 5249 5250 5251 5252 5253 5254 5255 5256 5257 5258 5259 5260 5261 5262 5263 5264 5265 5266 5267 5268 5269 5270 5271 5272 5273 5274 5275 5276 5277 5278 5279 5280 5281 5282 5283 5284 5285 5286 5287 5288 5289 5290 5291 5292 5293 5294 5295 5296 5297 5298 5299 5300 5301 5302 5303 5304 5305 5306 5307 5308 5309 5310 5311 5312 5313 5314 5315 5316 5317 5318 5319 5320 5321 5322 5323 5324 5325 5326 5327 5328 5329 5330 5331 5332 5333 5334 5335 5336 5337 5338 5339 5340 5341 5342 5343 5344 5345 5346 5347 5348 5349 5350 5351 5352 5353 5354 5355 5356 5357 5358 5359 5360 5361 5362 5363 5364 5365 5366 5367 5368 5369 5370 5371 5372 5373 5374 5375 5376 5377 5378 5379 5380 5381 5382 5383 5384 5385 5386 5387 5388 5389 5390 5391 5392 5393 5394 5395 5396 5397 5398 5399 5400 5401 5402 5403 5404 5405 5406 5407 5408 5409 5410 5411 5412 5413 5414 5415 5416 5417 5418 5419 5420 5421 5422 5423 5424 5425 5426 5427 5428 5429 5430 5431 5432 5433 5434 5435 5436 5437 5438 5439 5440 5441 5442 5443 5444 5445 5446 5447 5448 5449 5450 5451 5452 5453 5454 5455 5456 5457 5458 5459 5460 5461 5462 5463 5464 5465 5466 5467 5468 5469 5470 5471 5472 5473 5474 5475 5476 5477 5478 5479 5480 5481 5482 5483 5484 5485 5486 5487 5488 5489 5490 5491 5492 5493 5494 5495 5496 5497 5498 5499 5500 5501 5502 5503 5504 5505 5506 5507 5508 5509 5510 5511 5512 5513 5514 5515 5516 5517 5518 5519 5520 5521 5522 5523 5524 5525 5526 5527 5528 5529 5530 5531 5532 5533 5534 5535 5536 5537 5538 5539 5540 5541 5542 5543 5544 5545 5546 5547 5548 5549 5550 5551 5552 5553 5554 5555 5556 5557 5558 5559 5560 5561 5562 5563 5564 5565 5566 5567 5568 5569 5570 5571 5572 5573 5574 5575 5576 5577 5578 5579 5580 5581 5582 5583 5584 5585 5586 5587 5588 5589 5590 5591 5592 5593 5594 5595 5596 5597 5598 5599 5600 5601 5602 5603 5604 5605 5606 5607 5608 5609 5610 5611 5612 5613 5614 5615 5616 5617 5618 5619 5620 5621 5622 5623 5624 5625 5626 5627 5628 5629 5630 5631 5632 5633 5634 5635 5636 5637 5638 5639 5640 5641 5642 5643 5644 5645 5646 5647 5648 5649 5650 5651 5652 5653 5654 5655 5656 5657 5658 5659 5660 5661 5662 5663 5664 5665 5666 5667 5668 5669 5670 5671 5672 5673 5674 5675 5676 5677 5678 5679 5680 5681 5682 5683 5684 5685 5686 5687 5688 5689 5690 5691 5692 5693 5694 5695 5696 5697 5698 5699 5700 5701 5702 5703 5704 5705 5706 5707 5708 5709 5710 5711 5712 5713 5714 5715 5716 5717 5718 5719 5720 5721 5722 5723 5724 5725 5726 5727 5728 5729 5730 5731 5732 5733 5734 5735 5736 5737 5738 5739 5740 5741 5742 5743 5744 5745 5746 5747 5748 5749 5750 5751 5752 5753 5754 5755 5756 5757 5758 5759 5760 5761 5762 5763 5764 5765 5766 5767 5768 5769 5770 5771 5772 5773 5774 5775 5776 5777 5778 5779 5780 5781 5782 5783 5784 5785 5786 5787 5788 5789 5790 5791 5792 5793 5794 5795 5796 5797 5798 5799 5800 5801 5802 5803 5804 5805 5806 5807 5808 5809 5810 5811 5812 5813 5814 5815 5816 5817 5818 5819 5820 5821 5822 5823 5824 5825 5826 5827 5828 5829 5830 5831 5832 5833 5834 5835 5836 5837 5838 5839 5840 5841 5842 5843 5844 5845 5846 5847 5848 5849 5850 5851 5852 5853 5854 5855 5856 5857 5858 5859 5860 5861 5862 5863 5864 5865 5866 5867 5868 5869 5870 5871 5872 5873 5874 5875 5876 5877 5878 5879 5880 5881 5882 5883 5884 5885 5886 5887 5888 5889 5890 5891 5892 5893 5894 5895 5896 5897 5898 5899 5900 5901 5902 5903 5904 5905 5906 5907 5908 5909 5910 5911 5912 5913 5914 5915 5916 5917 5918 5919 5920 5921 5922 5923 5924 5925 5926 5927 5928 5929 5930 5931 5932 5933 5934 5935 5936 5937 5938 5939 5940 5941 5942 5943 5944 5945 5946 5947 5948 5949 5950 5951 5952 5953 5954 5955 5956 5957 5958 5959 5960 5961 5962 5963 5964 5965 5966 5967 5968 5969 5970 5971 5972 5973 5974 5975 5976 5977 5978 5979 5980 5981 5982 5983 5984 5985 5986 5987 5988 5989 5990 5991 5992 5993 5994 5995 5996 5997 5998 5999 6000 6001 6002 6003 6004 6005 6006 6007 6008 6009 6010 6011 6012 6013 6014 6015 6016 6017 6018 6019 6020 6021 6022 6023 6024 6025 6026 6027 6028 6029 6030 6031 6032 6033 6034 6035 6036 6037 6038 6039 6040 6041 6042 6043 6044 6045 6046 6047 6048 6049 6050 6051 6052 6053 6054 6055 6056 6057 6058 6059 6060 6061 6062 6063 6064 6065 6066 6067 6068 6069 6070 6071 6072 6073 6074 6075 6076 6077 6078 6079 6080 6081 6082 6083 6084 6085 6086 6087 6088 6089 6090 6091 6092 6093 6094 6095 6096 6097 6098 6099 6100 6101 6102 6103 6104 6105 6106 6107 6108 6109 6110 6111 6112 6113 6114 6115 6116 6117 6118 6119 6120 6121 6122 6123 6124 6125 6126 6127 6128 6129 6130 6131 6132 6133 6134 6135 6136 6137 6138 6139 6140 6141 6142 6143 6144 6145 6146 6147 6148 6149 6150 6151 6152 6153 6154 6155 6156 6157 6158 6159 6160 6161 6162 6163 6164 6165 6166 6167 6168 6169 6170 6171 6172 6173 6174 6175 6176 6177 6178 6179 6180 6181 6182 6183 6184 6185 6186 6187 6188 6189 6190 6191 6192 6193 6194 6195 6196 6197 6198 6199 6200 6201 6202 6203 6204 6205 6206 6207 6208 6209 6210 6211 6212 6213 6214 6215 6216 6217 6218 6219 6220 6221 6222 6223 6224 6225 6226 6227 6228 6229 6230 6231 6232 6233 6234 6235 6236 6237 6238 6239 6240 6241 6242 6243 6244 6245 6246 6247 6248 6249 6250 6251 6252 6253 6254 6255 6256 6257 6258 6259 6260 6261 6262 6263 6264 6265 6266 6267 6268 6269 6270 6271 6272 6273 6274 6275 6276 6277 6278 6279 6280 6281 6282 6283 6284 6285 6286 6287 6288 6289 6290 6291 6292 6293 6294 6295 6296 6297 6298 6299 6300 6301 6302 6303 6304 6305 6306 6307 6308 6309 6310 6311 6312 6313 6314 6315 6316 6317 6318 6319 6320 6321 6322 6323 6324 6325 6326 6327 6328 6329 6330 6331 6332 6333 6334 6335 6336 6337 6338 6339 6340 6341 6342 6343 6344 6345 6346 6347 6348 6349 6350 6351 6352 6353 6354 6355 6356 6357 6358 6359 6360 6361 6362 6363 6364 6365 6366 6367 6368 6369 6370 6371 6372 6373 6374 6375 6376 6377 6378 6379 6380 6381 6382 6383 6384 6385 6386 6387 6388 6389 6390 6391 6392 6393 6394 6395 6396 6397 6398 6399 6400 6401 6402 6403 6404 6405 6406 6407 6408 6409 6410 6411 6412 6413 6414 6415 6416 6417 6418 6419 6420 6421 6422 6423 6424 6425 6426 6427 6428 6429 6430 6431 6432 6433 6434 6435 6436 6437 6438 6439 6440 6441 6442 6443 6444 6445 6446 6447 6448 6449 6450 6451 6452 6453 6454 6455 6456 6457 6458 6459 6460 6461 6462 6463 6464 6465 6466 6467 6468 6469 6470 6471 6472 6473 6474 6475 6476 6477 6478 6479 6480 6481 6482 6483 6484 6485 6486 6487 6488 6489 6490 6491 6492 6493 6494 6495 6496 6497 6498 6499 6500 6501 6502 6503 6504 6505 6506 6507 6508 6509 6510 6511 6512 6513 6514 6515 6516 6517 6518 6519 6520 6521 6522 6523 6524 6525 6526 6527 6528 6529 6530 6531 6532 6533 6534 6535 6536 6537 6538 6539 6540 6541 6542 6543 6544 6545 6546 6547 6548 6549 6550 6551 6552 6553 6554 6555 6556 6557 6558 6559 6560 6561 6562 6563 6564 6565 6566 6567 6568 6569 6570 6571 6572 6573 6574 6575 6576 6577 6578 6579 6580 6581 6582 6583 6584 6585 6586 6587 6588 6589 6590 6591 6592 6593 6594 6595 6596 6597 6598 6599 6600 6601 6602 6603 6604 6605 6606 6607 6608 6609 6610 6611 6612 6613 6614 6615 6616 6617 6618 6619 6620 6621 6622 6623 6624 6625 6626 6627 6628 6629 6630 6631 6632 6633 6634 6635 6636 6637 6638 6639 6640 6641 6642 6643 6644 6645 6646 6647 6648 6649 6650 6651 6652 6653 6654 6655 6656 6657 6658 6659 6660 6661 6662 6663 6664 6665 6666 6667 6668 6669 6670 6671 6672 6673 6674 6675 6676 6677 6678 6679 6680 6681 6682 6683 6684 6685 6686 6687 6688 6689 6690 6691 6692 6693 6694 6695 6696 6697 6698 6699 6700 6701 6702 6703 6704 6705 6706 6707 6708 6709 6710 6711 6712 6713 6714 6715 6716 6717 6718 6719 6720 6721 6722 6723 6724 6725 6726 6727 6728 6729 6730 6731 6732 6733 6734 6735 6736 6737 6738 6739 6740 6741 6742 6743 6744 6745 6746 6747 6748 6749 6750 6751 6752 6753 6754 6755 6756 6757 6758 6759 6760 6761 6762 6763 6764 6765 6766 6767 6768 6769 6770 6771 6772 6773 6774 6775 6776 6777 6778 6779 6780 6781 6782 6783 6784 6785 6786 6787 6788 6789 6790 6791 6792 6793 6794 6795 6796 6797 6798 6799 6800 6801 6802 6803 6804 6805 6806 6807 6808 6809 6810 6811 6812 6813 6814 6815 6816 6817 6818 6819 6820 6821 6822 6823 6824 6825 6826 6827 6828 6829 6830 6831 6832 6833 6834 6835 6836 6837 6838 6839 6840 6841 6842 6843 6844 6845 6846 6847 6848 6849 6850 6851 6852 6853 6854 6855 6856 6857 6858 6859 6860 6861 6862 6863 6864 6865 6866 6867 6868 6869 6870 6871 6872 6873 6874 6875 6876 6877 6878 6879 6880 6881 6882 6883 6884 6885 6886 6887 6888 6889 6890 6891 6892 6893 6894 6895 6896 6897 6898 6899 6900 6901 6902 6903 6904 6905 6906 6907 6908 6909 6910 6911 6912 6913 6914 6915 6916 6917 6918 6919 6920 6921 6922 6923 6924 6925 6926 6927 6928 6929 6930 6931 6932 6933 6934 6935 6936 6937 6938 6939 6940 6941 6942 6943 6944 6945 6946 6947 6948 6949 6950 6951 6952 6953 6954 6955 6956 6957 6958 6959 6960 6961 6962 6963 6964 6965 6966 6967 6968 6969 6970 6971 6972 6973 6974 6975 6976 6977 6978 6979 6980 6981 6982 6983 6984 6985 6986 6987 6988 6989 6990 6991 6992 6993 6994 6995 6996 6997 6998 6999 7000 7001 7002 7003 7004 7005 7006 7007 7008 7009 7010 7011 7012 7013 7014 7015 7016 7017 7018 7019 7020 7021 7022 7023 7024 7025 7026 7027 7028 7029 7030 7031 7032 7033 7034 7035 7036 7037 7038 7039 7040 7041 7042 7043 7044 7045 7046 7047 7048 7049 7050 7051 7052 7053 7054 7055 7056 7057 7058 7059 7060 7061 7062 7063 7064 7065 7066 7067 7068 7069 7070 7071 7072 7073 7074 7075 7076 7077 7078 7079 7080 7081 7082 7083 7084 7085 7086 7087 7088 7089 7090 7091 7092 7093 7094 7095 7096 7097 7098 7099 7100 7101 7102 7103 7104 7105 7106 7107 7108 7109 7110 7111 7112 7113 7114 7115 7116 7117 7118 7119 7120 7121 7122 7123 7124 7125 7126 7127 7128 7129 7130 7131 7132 7133 7134 7135 7136 7137 7138 7139 7140 7141 7142 7143 7144 7145 7146 7147 7148 7149 7150 7151 7152 7153 7154 7155 7156 7157 7158 7159 7160 7161 7162 7163 7164 7165 7166 7167 7168 7169 7170 7171 7172 7173 7174 7175 7176 7177 7178 7179 7180 7181 7182 7183 7184 7185 7186 7187 7188 7189 7190 7191 7192 7193 7194 7195 7196 7197 7198 7199 7200 7201 7202 7203 7204 7205 7206 7207 7208 7209 7210 7211 7212 7213 7214 7215 7216 7217 7218 7219 7220 7221 7222 7223 7224 7225 7226 7227 7228 7229 7230 7231 7232 7233 7234 7235 7236 7237 7238 7239 7240 7241 7242 7243 7244 7245 7246 7247 7248 7249 7250 7251 7252 7253 7254 7255 7256 7257 7258 7259 7260 7261 7262 7263 7264 7265 7266 7267 7268 7269 7270 7271 7272 7273 7274 7275 7276 7277 7278 7279 7280 7281 7282 7283 7284 7285 7286 7287 7288 7289 7290 7291 7292 7293 7294 7295 7296 7297 7298 7299 7300 7301 7302 7303 7304 7305 7306 7307 7308 7309 7310 7311 7312 7313 7314 7315 7316 7317 7318 7319 7320 7321 7322 7323 7324 7325 7326 7327 7328 7329 7330 7331 7332 7333 7334 7335 7336 7337 7338 7339 7340 7341 7342 7343 7344 7345 7346 7347 7348 7349 7350 7351 7352 7353 7354 7355 7356 7357 7358 7359 7360 7361 7362 7363 7364 7365 7366 7367 7368 7369 7370 7371 7372 7373 7374 7375 7376 7377 7378 7379 7380 7381 7382 7383 7384 7385 7386 7387 7388 7389 7390 7391 7392 7393 7394 7395 7396 7397 7398 7399 7400 7401 7402 7403 7404 7405 7406 7407 7408 7409 7410 7411 7412 7413 7414 7415 7416 7417 7418 7419 7420 7421 7422 7423 7424 7425 7426 7427 7428 7429 7430 7431 7432 7433 7434 7435 7436 7437 7438 7439 7440 7441 7442 7443 7444 7445 7446 7447 7448 7449 7450 7451 7452 7453 7454 7455 7456 7457 7458 7459 7460 7461 7462 7463 7464 7465 7466 7467 7468 7469 7470 7471 7472 7473 7474 7475 7476 7477 7478 7479 7480 7481 7482 7483 7484 7485 7486 7487 7488 7489 7490 7491 7492 7493 7494 7495 7496 7497 7498 7499 7500 7501 7502 7503 7504 7505 7506 7507 7508 7509 7510 7511 7512 7513 7514 7515 7516 7517 7518 7519 7520 7521 7522 7523 7524 7525 7526 7527 7528 7529 7530 7531 7532 7533 7534 7535 7536 7537 7538 7539 7540 7541 7542 7543 7544 7545 7546 7547 7548 7549 7550 7551 7552 7553 7554 7555 7556 7557 7558 7559 7560 7561 7562 7563 7564 7565 7566 7567 7568 7569 7570 7571 7572 7573 7574 7575 7576 7577 7578 7579 7580 7581 7582 7583 7584 7585 7586 7587 7588 7589 7590 7591 7592 7593 7594 7595 7596 7597 7598 7599 7600 7601 7602 7603 7604 7605 7606 7607 7608 7609 7610 7611 7612 7613 7614 7615 7616 7617 7618 7619 7620 7621 7622 7623 7624 7625 7626 7627 7628 7629 7630 7631 7632 7633 7634 7635 7636 7637 7638 7639 7640 7641 7642 7643 7644 7645 7646 7647 7648 7649 7650 7651 7652 7653 7654 7655 7656 7657 7658 7659 7660 7661 7662 7663 7664 7665 7666 7667 7668 7669 7670 7671 7672 7673 7674 7675 7676 7677 7678 7679 7680 7681 7682 7683 7684 7685 7686 7687 7688 7689 7690 7691 7692 7693 7694 7695 7696 7697 7698 7699 7700 7701 7702 7703 7704 7705 7706 7707 7708 7709 7710 7711 7712 7713 7714 7715 7716 7717 7718 7719 7720 7721 7722 7723 7724 7725 7726 7727 7728 7729 7730 7731 7732 7733 7734 7735 7736 7737 7738 7739 7740 7741 7742 7743 7744 7745 7746 7747 7748 7749 7750 7751 7752 7753 7754 7755 7756 7757 7758 7759 7760 7761 7762 7763 7764 7765 7766 7767 7768 7769 7770 7771 7772 7773 7774 7775 7776 7777 7778 7779 7780 7781 7782 7783 7784 7785 7786 7787 7788 7789 7790 7791 7792 7793 7794 7795 7796 7797 7798 7799 7800 7801 7802 7803 7804 7805 7806 7807 7808 7809 7810 7811 7812 7813 7814 7815 7816 7817 7818 7819 7820 7821 7822 7823 7824 7825 7826 7827 7828 7829 7830 7831 7832 7833 7834 7835 7836 7837 7838 7839 7840 7841 7842 7843 7844 7845 7846 7847 7848 7849 7850 7851 7852 7853 7854 7855 7856 7857 7858 7859 7860 7861 7862 7863 7864 7865 7866 7867 7868 7869 7870 7871 7872 7873 7874 7875 7876 7877 7878 7879 7880 7881 7882 7883 7884 7885 7886 7887 7888 7889 7890 7891 7892 7893 7894 7895 7896 7897 7898 7899 7900 7901 7902 7903 7904 7905 7906 7907 7908 7909 7910 7911 7912 7913 7914 7915 7916 7917 7918 7919 7920 7921 7922 7923 7924 7925 7926 7927 7928 7929 7930 7931 7932 7933 7934 7935 7936 7937 7938 7939 7940 7941 7942 7943 7944 7945 7946 7947 7948 7949 7950 7951 7952 7953 7954 7955 7956 7957 7958 7959 7960 7961 7962 7963 7964 7965 7966 7967 7968 7969 7970 7971 7972 7973 7974 7975 7976 7977 7978 7979 7980 7981 7982 7983 7984 7985 7986 7987 7988 7989 7990 7991 7992 7993 7994 7995 7996 7997 7998 7999 8000 8001 8002 8003 8004 8005 8006 8007 8008 8009 8010 8011 8012 8013 8014 8015 8016 8017 8018 8019 8020 8021 8022 8023 8024 8025 8026 8027 8028 8029 8030 8031 8032 8033 8034 8035 8036 8037 8038 8039 8040 8041 8042 8043 8044 8045 8046 8047 8048 8049 8050 8051 8052 8053 8054 8055 8056 8057 8058 8059 8060 8061 8062 8063 8064 8065 8066 8067 8068 8069 8070 8071 8072 8073 8074 8075 8076 8077 8078 8079 8080 8081 8082 8083 8084 8085 8086 8087 8088 8089 8090 8091 8092 8093 8094 8095 8096 8097 8098 8099 8100 8101 8102 8103 8104 8105 8106 8107 8108 8109 8110 8111 8112 8113 8114 8115 8116 8117 8118 8119 8120 8121 8122 8123 8124 8125 8126 8127 8128 8129 8130 8131 8132 8133 8134 8135 8136 8137 8138 8139 8140 8141 8142 8143 8144 8145 8146 8147 8148 8149 8150 8151 8152 8153 8154 8155 8156 8157 8158 8159 8160 8161 8162 8163 8164 8165 8166 8167 8168 8169 8170 8171 8172 8173 8174 8175 8176 8177 8178 8179 8180 8181 8182 8183 8184 8185 8186 8187 8188 8189 8190 8191 8192 8193 8194 8195 8196 8197 8198 8199 8200 8201 8202 8203 8204 8205 8206 8207 8208 8209 8210 8211 8212 8213 8214 8215 8216 8217 8218 8219 8220 8221 8222 8223 8224 8225 8226 8227 8228 8229 8230 8231 8232 8233 8234 8235 8236 8237 8238 8239 8240 8241 8242 8243 8244 8245 8246 8247 8248 8249 8250 8251 8252 8253 8254 8255 8256 8257 8258 8259 8260 8261 8262 8263 8264 8265 8266 8267 8268 8269 8270 8271 8272 8273 8274 8275 8276 8277 8278 8279 8280 8281 8282 8283 8284 8285 8286 8287 8288 8289 8290 8291 8292 8293 8294 8295 8296 8297 8298 8299 8300 8301 8302 8303 8304 8305 8306 8307 8308 8309 8310 8311 8312 8313 8314 8315 8316 8317 8318 8319 8320 8321 8322 8323 8324 8325 8326 8327 8328 8329 8330 8331 8332 8333 8334 8335 8336 8337 8338 8339 8340 8341 8342 8343 8344 8345 8346 8347 8348 8349 8350 8351 8352 8353 8354 8355 8356 8357 8358 8359 8360 8361 8362 8363 8364 8365 8366 8367 8368 8369 8370 8371 8372 8373 8374 8375 8376 8377 8378 8379 8380 8381 8382 8383 8384 8385 8386 8387 8388 8389 8390 8391 8392 8393 8394 8395 8396 8397 8398 8399 8400 8401 8402 8403 8404 8405 8406 8407 8408 8409 8410 8411 8412 8413 8414 8415 8416 8417 8418 8419 8420 8421 8422 8423 8424 8425 8426 8427 8428 8429 8430 8431 8432 8433 8434 8435 8436 8437 8438 8439 8440 8441 8442 8443 8444 8445 8446 8447 8448 8449 8450 8451 8452 8453 8454 8455 8456 8457 8458 8459 8460 8461 8462 8463 8464 8465 8466 8467 8468 8469 8470 8471 8472 8473 8474 8475 8476 8477 8478 8479 8480 8481 8482 8483 8484 8485 8486 8487 8488 8489 8490 8491 8492 8493 8494 8495 8496 8497 8498 8499 8500 8501 8502 8503 8504 8505 8506 8507 8508 8509 8510 8511 8512 8513 8514 8515 8516 8517 8518 8519 8520 8521 8522 8523 8524 8525 8526 8527 8528 8529 8530 8531 8532 8533 8534 8535 8536 8537 8538 8539 8540 8541 8542 8543 8544 8545 8546 8547 8548 8549 8550 8551 8552 8553 8554 8555 8556 8557 8558 8559 8560 8561 8562 8563 8564 8565 8566 8567 8568 8569 8570 8571 8572 8573 8574 8575 8576 8577 8578 8579 8580 8581 8582 8583 8584 8585 8586 8587 8588 8589 8590 8591 8592 8593 8594 8595 8596 8597 8598 8599 8600 8601 8602 8603 8604 8605 8606 8607 8608 8609 8610 8611 8612 8613 8614 8615 8616 8617 8618 8619 8620 8621 8622 8623 8624 8625 8626 8627 8628 8629 8630 8631 8632 8633 8634 8635 8636 8637 8638 8639 8640 8641 8642 8643 8644 8645 8646 8647 8648 8649 8650 8651 8652 8653 8654 8655 8656 8657 8658 8659 8660 8661 8662 8663 8664 8665 8666 8667 8668 8669 8670 8671 8672 8673 8674 8675 8676 8677 8678 8679 8680 8681 8682 8683 8684 8685 8686 8687 8688 8689 8690 8691 8692 8693 8694 8695 8696 8697 8698 8699 8700 8701 8702 8703 8704 8705 8706 8707 8708 8709 8710 8711 8712 8713 8714 8715 8716 8717 8718 8719 8720 8721 8722 8723 8724 8725 8726 8727 8728 8729 8730 8731 8732 8733 8734 8735 8736 8737 8738 8739 8740 8741 8742 8743 8744 8745 8746 8747 8748 8749 8750 8751 8752 8753 8754 8755 8756 8757 8758 8759 8760 8761 8762 8763 8764 8765 8766 8767 8768 8769 8770 8771 8772 8773 8774 8775 8776 8777 8778 8779 8780 8781 8782 8783 8784 8785 8786 8787 8788 8789 8790 8791 8792 8793 8794 8795 8796 8797 8798 8799 8800 8801 8802 8803 8804 8805 8806 8807 8808 8809 8810 8811 8812 8813 8814 8815 8816 8817 8818 8819 8820 8821 8822 8823 8824 8825 8826 8827 8828 8829 8830 8831 8832 8833 8834 8835 8836 8837 8838 8839 8840 8841 8842 8843 8844 8845 8846 8847 8848 8849 8850 8851 8852 8853 8854 8855 8856 8857 8858 8859 8860 8861 8862 8863 8864 8865 8866 8867 8868 8869 8870 8871 8872 8873 8874 8875 8876 8877 8878 8879 8880 8881 8882 8883 8884 8885 8886 8887 8888 8889 8890 8891 8892 8893 8894 8895 8896 8897 8898 8899 8900 8901 8902 8903 8904 8905 8906 8907 8908 8909 8910 8911 8912 8913 8914 8915 8916 8917 8918 8919 8920 8921 8922 8923 8924 8925 8926 8927 8928 8929 8930 8931 8932 8933 8934 8935 8936 8937 8938 8939 8940 8941 8942 8943 8944 8945 8946 8947 8948 8949 8950 8951 8952 8953 8954 8955 8956 8957 8958 8959 8960 8961 8962 8963 8964 8965 8966 8967 8968 8969 8970 8971 8972 8973 8974 8975 8976 8977 8978 8979 8980 8981 8982 8983 8984 8985 8986 8987 8988 8989 8990 8991 8992 8993 8994 8995 8996 8997 8998 8999 9000 9001 9002 9003 9004 9005 9006 9007 9008 9009 9010 9011 9012 9013 9014 9015 9016 9017 9018 9019 9020 9021 9022 9023 9024 9025 9026 9027 9028 9029 9030 9031 9032 9033 9034 9035 9036 9037 9038 9039 9040 9041 9042 9043 9044 9045 9046 9047 9048 9049 9050 9051 9052 9053 9054 9055 9056 9057 9058 9059 9060 9061 9062 9063 9064 9065 9066 9067 9068 9069 9070 9071 9072 9073 9074 9075 9076 9077 9078 9079 9080 9081 9082 9083 9084 9085 9086 9087 9088 9089 9090 9091 9092 9093 9094 9095 9096 9097 9098 9099 9100 9101 9102 9103 9104 9105 9106 9107 9108 9109 9110 9111 9112 9113 9114 9115 9116 9117 9118 9119 9120 9121 9122 9123 9124 9125 9126 9127 9128 9129 9130 9131 9132 9133 9134 9135 9136 9137 9138 9139 9140 9141 9142 9143 9144 9145 9146 9147 9148 9149 9150 9151 9152 9153 9154 9155 9156 9157 9158 9159 9160 9161 9162 9163 9164 9165 9166 9167 9168 9169 9170 9171 9172 9173 9174 9175 9176 9177 9178 9179 9180 9181 9182 9183 9184 9185 9186 9187 9188 9189 9190 9191 9192 9193 9194 9195 9196 9197 9198 9199 9200 9201 9202 9203 9204 9205 9206 9207 9208 9209 9210 9211 9212 9213 9214 9215 9216 9217 9218 9219 9220 9221 9222 9223 9224 9225 9226 9227 9228 9229 9230 9231 9232 9233 9234 9235 9236 9237 9238 9239 9240 9241 9242 9243 9244 9245 9246 9247 9248 9249 9250 9251 9252 9253 9254 9255 9256 9257 9258 9259 9260 9261 9262 9263 9264 9265 9266 9267 9268 9269 9270 9271 9272 9273 9274 9275 9276 9277 9278 9279 9280 9281 9282 9283 9284 9285 9286 9287 9288 9289 9290 9291 9292 9293 9294 9295 9296 9297 9298 9299 9300 9301 9302 9303 9304 9305 9306 9307 9308 9309 9310 9311 9312 9313 9314 9315 9316 9317 9318 9319 9320 9321 9322 9323 9324 9325 9326 9327 9328 9329 9330 9331 9332 9333 9334 9335 9336 9337 9338 9339 9340 9341 9342 9343 9344 9345 9346 9347 9348 9349 9350 9351 9352 9353 9354 9355 9356 9357 9358 9359 9360 9361 9362 9363 9364 9365 9366 9367 9368 9369 9370 9371 9372 9373 9374 9375 9376 9377 9378 9379 9380 9381 9382 9383 9384 9385 9386 9387 9388 9389 9390 9391 9392 9393 9394 9395 9396 9397 9398 9399 9400 9401 9402 9403 9404 9405 9406 9407 9408 9409 9410 9411 9412 9413 9414 9415 9416 9417 9418 9419 9420 9421 9422 9423 9424 9425 9426 9427 9428 9429 9430 9431 9432 9433 9434 9435 9436 9437 9438 9439 9440 9441 9442 9443 9444 9445 9446 9447 9448 9449 9450 9451 9452 9453 9454 9455 9456 9457 9458 9459 9460 9461 9462 9463 9464 9465 9466 9467 9468 9469 9470 9471 9472 9473 9474 9475 9476 9477 9478 9479 9480 9481 9482 9483 9484 9485 9486 9487 9488 9489 9490 9491 9492 9493 9494 9495 9496 9497 9498 9499 9500 9501 9502 9503 9504 9505 9506 9507 9508 9509 9510 9511 9512 9513 9514 9515 9516 9517 9518 9519 9520 9521 9522 9523 9524 9525 9526 9527 9528 9529 9530 9531 9532 9533 9534 9535 9536 9537 9538 9539 9540 9541 9542 9543 9544 9545 9546 9547 9548 9549 9550 9551 9552 9553 9554 9555 9556 9557 9558 9559 9560 9561 9562 9563 9564 9565 9566 9567 9568 9569 9570 9571 9572 9573 9574 9575 9576 9577 9578 9579 9580 9581 9582 9583 9584 9585 9586 9587 9588 9589 9590 9591 9592 9593 9594 9595 9596 9597 9598 9599 9600 9601 9602 9603 9604 9605 9606 9607 9608 9609 9610 9611 9612 9613 9614 9615 9616 9617 9618 9619 9620 9621 9622 9623 9624 9625 9626 9627 9628 9629 9630 9631 9632 9633 9634 9635 9636 9637 9638 9639 9640 9641 9642 9643 9644 9645 9646 9647 9648 9649 9650 9651 9652 9653 9654 9655 9656 9657 9658 9659 9660 9661 9662 9663 9664 9665 9666 9667 9668 9669 9670 9671 9672 9673 9674 9675 9676 9677 9678 9679 9680 9681 9682 9683 9684 9685 9686 9687 9688 9689 9690 9691 9692 9693 9694 9695 9696 9697 9698 9699 9700 9701 9702 9703 9704 9705 9706 9707 9708 9709 9710 9711 9712 9713 9714 9715 9716 9717 9718 9719 9720 9721 9722 9723 9724 9725 9726 9727 9728 9729 9730 9731 9732 9733 9734 9735 9736 9737 9738 9739 9740 9741 9742 9743 9744 9745 9746 9747 9748 9749 9750 9751 9752 9753 9754 9755 9756 9757 9758 9759 9760 9761 9762 9763 9764 9765 9766 9767 9768 9769 9770 9771 9772 9773 9774 9775 9776 9777 9778 9779 9780 9781 9782 9783 9784 9785 9786 9787 9788 9789 9790 9791 9792 9793 9794 9795 9796 9797 9798 9799 9800 9801 9802 9803 9804 9805 9806 9807 9808 9809 9810 9811 9812 9813 9814 9815 9816 9817 9818 9819 9820 9821 9822 9823 9824 9825 9826 9827 9828 9829 9830 9831 9832 9833 9834 9835 9836 9837 9838 9839 9840 9841 9842 9843 9844 9845 9846 9847 9848 9849 9850 9851 9852 9853 9854 9855 9856 9857 9858 9859 9860 9861 9862 9863 9864 9865 9866 9867 9868 9869 9870 9871 9872 9873 9874 9875 9876 9877 9878 9879 9880 9881 9882 9883 9884 9885 9886 9887 9888 9889 9890 9891 9892 9893 9894 9895 9896 9897 9898 9899 9900 9901 9902 9903 9904 9905 9906 9907 9908 9909 9910 9911 9912 9913 9914 9915 9916 9917 9918 9919 9920 9921 9922 9923 9924 9925 9926 9927 9928 9929 9930 9931 9932 9933 9934 9935 9936 9937 9938 9939
|
Chapter 2 Installing and Upgrading MySQL
This chapter describes how to obtain and install MySQL. A
summary of the procedure follows and later sections provide
the details. If you plan to upgrade an existing version of
MySQL to a newer version rather than install MySQL for the
first time, see Section 2.11.1, "Upgrading MySQL," for
information about upgrade procedures and about issues that
you should consider before upgrading.
If you are interested in migrating to MySQL from another
database system, you may wish to read Section A.8, "MySQL 5.5
FAQ: Migration," which contains answers to some common
questions concerning migration issues.
If you are migrating from MySQL Enterprise Edition to MySQL
Community Server, see Section 2.11.2.2, "Downgrading from
MySQL Enterprise Edition to MySQL Community Server."
Installation of MySQL generally follows the steps outlined
here:
1. Determine whether MySQL runs and is supported on your
platform.
Please note that not all platforms are equally suitable
for running MySQL, and that not all platforms on which
MySQL is known to run are officially supported by Oracle
Corporation.
2. Choose which distribution to install.
Several versions of MySQL are available, and most are
available in several distribution formats. You can choose
from pre-packaged distributions containing binary
(precompiled) programs or source code. When in doubt, use
a binary distribution. We also provide public access to
our current source tree for those who want to see our
most recent developments and help us test new code. To
determine which version and type of distribution you
should use, see Section 2.1.1, "Which MySQL Version and
Distribution to Install."
3. Download the distribution that you want to install.
For instructions, see Section 2.1.2, "How to Get MySQL."
To verify the integrity of the distribution, use the
instructions in Section 2.1.3, "Verifying Package
Integrity Using MD5 Checksums or GnuPG."
4. Install the distribution.
To install MySQL from a binary distribution, use the
instructions in Section 2.2, "Installing MySQL on
Unix/Linux Using Generic Binaries."
To install MySQL from a source distribution or from the
current development source tree, use the instructions in
Section 2.9, "Installing MySQL from Source."
5. Perform any necessary postinstallation setup.
After installing MySQL, see Section 2.10,
"Postinstallation Setup and Testing" for information
about making sure the MySQL server is working properly.
Also refer to the information provided in Section 2.10.4,
"Securing the Initial MySQL Accounts." This section
describes how to secure the initial MySQL user accounts,
which have no passwords until you assign passwords. The
section applies whether you install MySQL using a binary
or source distribution.
6. If you want to run the MySQL benchmark scripts, Perl
support for MySQL must be available. See Section 2.13,
"Perl Installation Notes."
Instructions for installing MySQL on different platforms and
environments is available on a platform by platform basis:
* Unix, Linux, FreeBSD
For instructions on installing MySQL on most Linux and
Unix platforms using a generic binary (for example, a
.tar.gz package), see Section 2.2, "Installing MySQL on
Unix/Linux Using Generic Binaries."
For information on building MySQL entirely from the
source code distributions or the source code
repositories, see Section 2.9, "Installing MySQL from
Source"
For specific platform help on installation,
configuration, and building from source see the
corresponding platform section:
+ Linux, including notes on distribution specific
methods, see Section 2.5, "Installing MySQL on
Linux."
+ Solaris and OpenSolaris, including PKG and IPS
formats, see Section 2.7, "Installing MySQL on
Solaris and OpenSolaris."
+ IBM AIX, see Section 2.7, "Installing MySQL on
Solaris and OpenSolaris."
+ FreeBSD, see Section 2.8, "Installing MySQL on
FreeBSD."
* Microsoft Windows
For instructions on installing MySQL on Microsoft
Windows, using either the MySQL Installer standalone MSI,
or Zipped binary, see Section 2.3, "Installing MySQL on
Microsoft Windows."
For information about managing MySQL instances, see
Section 2.3.4, "MySQL Notifier."
For details and instructions on building MySQL from
source code using Microsoft Visual Studio, see Section
2.9, "Installing MySQL from Source."
* OS X
For installation on OS X, including using both the binary
package and native PKG formats, see Section 2.4,
"Installing MySQL on OS X."
For information on making use of an OS X Launch Daemon to
automatically start and stop MySQL, see Section 2.4.3,
"Installing a MySQL Launch Daemon."
For information on the MySQL Preference Pane, see Section
2.4.4, "Installing and Using the MySQL Preference Pane."
2.1 General Installation Guidance
The immediately following sections contain the information
necessary to choose, download, and verify your distribution.
The instructions in later sections of the chapter describe
how to install the distribution that you choose. For binary
distributions, see the instructions at Section 2.2,
"Installing MySQL on Unix/Linux Using Generic Binaries" or
the corresponding section for your platform if available. To
build MySQL from source, use the instructions in Section 2.9,
"Installing MySQL from Source."
2.1.1 Which MySQL Version and Distribution to Install
MySQL is available on a number of operating systems and
platforms. For information about those platforms that are
officially supported, see
http://www.mysql.com/support/supportedplatforms/database.html
on the MySQL Web site.
When preparing to install MySQL, you should decide which
version to use, and which distribution format (binary or
source) to use for the installation.
First, decide if you want to install a development release or
a GA release. Development releases have the newest features,
but are not recommended for production use. GA (General
Availability) releases, also called production or stable
releases, are meant for production use. We recommend to use
the most recent GA release.
The naming scheme in MySQL 5.5 uses release names that
consist of three numbers and a suffix; for example,
mysql-5.6.1-m1. The numbers within the release name are
interpreted as follows:
* The first number (5) is the major version and describes
the file format. All MySQL 5 releases have the same file
format.
* The second number (6) is the release level. Taken
together, the major version and release level constitute
the release series number.
* The third number (1) is the version number within the
release series. This is incremented for each new release.
Usually you want the latest version for the series you
have chosen.
For each minor update, the last number in the version string
is incremented. When there are major new features or minor
incompatibilities with previous versions, the second number
in the version string is incremented. When the file format
changes, the first number is increased.
Release names can also include a suffix that indicates the
stability level of the release. Releases within a series
progress through a set of suffixes to indicate how the
stability level improves. The possible suffixes are:
* If there is no suffix, it indicates that the release is a
General Availability (GA) or Production release. GA
releases are stable, having successfully passed through
all earlier release stages and are believed to be
reliable, free of serious bugs, and suitable for use in
production systems. Only critical bugfixes are applied to
the release.
* mN (for example, m1, m2, m3, ...) indicate a milestone
number. MySQL development uses a milestone model, in
which each milestone proceeds through a small number of
versions with a tight focus on a small subset of
thoroughly tested features. Following the releases for
one milestone, development proceeds with another small
number of releases that focuses on the next small set of
features, also thoroughly tested. Features within
milestone releases may be considered to be of
pre-production quality.
* rc indicates a Release Candidate. Release candidates are
believed to be stable, having passed all of MySQL's
internal testing, and with all known fatal runtime bugs
fixed. However, the release has not been in widespread
use long enough to know for sure that all bugs have been
identified. Only minor fixes are added.
Once you've chosen which MySQL version to install, you need
to decide which distribution to install for your operating
system. For most use cases, a binary distribution is the
right choice. Binary distributions are available in native
format for many platforms, such as RPM packages for Linux, or
DMG packages for OS X. Distributions are also available in
more generic formats such as Zip archives or compressed tar
files. On Windows, you can use the MySQL Installer to install
a binary distribution.
Under some circumstances, you may be better off installing
MySQL from a source distribution:
* You want to install MySQL at some explicit location. The
standard binary distributions are ready to run at any
installation location, but you might require even more
flexibility to place MySQL components where you want.
* You want to configure mysqld to ensure that features are
available that might not be included in the standard
binary distributions. Here is a list of the most common
extra options that you may want to use to ensure feature
availability:
+ -DWITH_LIBWRAP=1 for TCP wrappers support.
+ -DWITH_ZLIB={system|bundled} for features that
depend on compression
+ -DWITH_DEBUG=1 for debugging support
For additional information, see Section 2.9.4, "MySQL
Source-Configuration Options."
* You want to configure mysqld without some features that
are included in the standard binary distributions. For
example, distributions normally are compiled with support
for all character sets. If you want a smaller MySQL
server, you can recompile it with support for only the
character sets you need.
* You want to use the latest sources from one of the Git
repositories to have access to all current bugfixes. For
example, if you have found a bug and reported it to the
MySQL development team, the bugfix is committed to the
source repository and you can access it there. The bugfix
does not appear in a release until a release actually is
issued.
* You want to read (or modify) the C and C++ code that
makes up MySQL. For this purpose, you should get a source
distribution.
* Source distributions contain more tests and examples than
binary distributions.
2.1.2 How to Get MySQL
Check our downloads page at http://dev.mysql.com/downloads/
for information about the current version of MySQL and for
downloading instructions. For a complete up-to-date list of
MySQL download mirror sites, see
http://dev.mysql.com/downloads/mirrors.html. You can also
find information there about becoming a MySQL mirror site and
how to report a bad or out-of-date mirror.
To obtain the latest development source, see Section 2.9.3,
"Installing MySQL Using a Development Source Tree."
2.1.3 Verifying Package Integrity Using MD5 Checksums or GnuPG
After you have downloaded the MySQL package that suits your
needs and before you attempt to install it, you should make
sure that it is intact and has not been tampered with. There
are three means of integrity checking:
* MD5 checksums
* Cryptographic signatures using GnuPG, the GNU Privacy
Guard
* For RPM packages, the built-in RPM integrity verification
mechanism
The following sections describe how to use these methods.
If you notice that the MD5 checksum or GPG signatures do not
match, first try to download the respective package one more
time, perhaps from another mirror site.
2.1.3.1 Verifying the MD5 Checksum
After you have downloaded a MySQL package, you should make
sure that its MD5 checksum matches the one provided on the
MySQL download pages. Each package has an individual checksum
that you can verify against the package that you downloaded.
The correct MD5 checksum is listed on the downloads page for
each MySQL product, and you will compare it against the MD5
checksum of the file (product) that you download.
Each operating system and setup offers its own version of
tools for checking the MD5 checksum. Typically the command is
named md5sum, or it may be named md5, and some operating
systems do not ship it at all. On Linux, it is part of the
GNU Text Utilities package, which is available for a wide
range of platforms. You can also download the source code
from http://www.gnu.org/software/textutils/. If you have
OpenSSL installed, you can use the command openssl md5
package_name instead. A Windows implementation of the md5
command line utility is available from
http://www.fourmilab.ch/md5/. winMd5Sum is a graphical MD5
checking tool that can be obtained from
http://www.nullriver.com/index/products/winmd5sum. Our
Microsoft Windows examples will assume the name md5.exe.
Linux and Microsoft Windows examples:
shell> md5sum mysql-standard-5.5.47-linux-i686.tar.gz
aaab65abbec64d5e907dcd41b8699945 mysql-standard-5.5.47-linux-i686.tar
.gz
shell> md5.exe mysql-installer-community-5.5.47.msi
aaab65abbec64d5e907dcd41b8699945 mysql-installer-community-5.5.47.msi
You should verify that the resulting checksum (the string of
hexadecimal digits) matches the one displayed on the download
page immediately below the respective package.
Note
Make sure to verify the checksum of the archive file (for
example, the .zip, .tar.gz, or .msi file) and not of the
files that are contained inside of the archive. In other
words, verify the file before extracting its contents.
2.1.3.2 Signature Checking Using GnuPG
Another method of verifying the integrity and authenticity of
a package is to use cryptographic signatures. This is more
reliable than using MD5 checksums, but requires more work.
We sign MySQL downloadable packages with GnuPG (GNU Privacy
Guard). GnuPG is an Open Source alternative to the well-known
Pretty Good Privacy (PGP) by Phil Zimmermann. See
http://www.gnupg.org/ for more information about GnuPG and
how to obtain and install it on your system. Most Linux
distributions ship with GnuPG installed by default. For more
information about GnuPG, see http://www.openpgp.org/.
To verify the signature for a specific package, you first
need to obtain a copy of our public GPG build key, which you
can download from http://pgp.mit.edu/. The key that you want
to obtain is named mysql-build@oss.oracle.com. Alternatively,
you can cut and paste the key directly from the following
text:
-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: GnuPG v1.4.9 (SunOS)
mQGiBD4+owwRBAC14GIfUfCyEDSIePvEW3SAFUdJBtoQHH/nJKZyQT7h9bPlUWC3
RODjQReyCITRrdwyrKUGku2FmeVGwn2u2WmDMNABLnpprWPkBdCk96+OmSLN9brZ
fw2vOUgCmYv2hW0hyDHuvYlQA/BThQoADgj8AW6/0Lo7V1W9/8VuHP0gQwCgvzV3
BqOxRznNCRCRxAuAuVztHRcEAJooQK1+iSiunZMYD1WufeXfshc57S/+yeJkegNW
hxwR9pRWVArNYJdDRT+rf2RUe3vpquKNQU/hnEIUHJRQqYHo8gTxvxXNQc7fJYLV
K2HtkrPbP72vwsEKMYhhr0eKCbtLGfls9krjJ6sBgACyP/Vb7hiPwxh6rDZ7ITnE
kYpXBACmWpP8NJTkamEnPCia2ZoOHODANwpUkP43I7jsDmgtobZX9qnrAXw+uNDI
QJEXM6FSbi0LLtZciNlYsafwAPEOMDKpMqAK6IyisNtPvaLd8lH0bPAnWqcyefep
rv0sxxqUEMcM3o7wwgfN83POkDasDbs3pjwPhxvhz6//62zQJ7Q2TXlTUUwgUmVs
ZWFzZSBFbmdpbmVlcmluZyA8bXlzcWwtYnVpbGRAb3NzLm9yYWNsZS5jb20+iGkE
ExECACkCGyMGCwkIBwMCBBUCCAMEFgIDAQIeAQIXgAIZAQUCUwHUZgUJGmbLywAK
CRCMcY07UHLh9V+DAKCjS1gGwgVI/eut+5L+l2v3ybl+ZgCcD7ZoA341HtoroV3U
6xRD09fUgeq0O015U1FMIFBhY2thZ2Ugc2lnbmluZyBrZXkgKHd3dy5teXNxbC5j
b20pIDxidWlsZEBteXNxbC5jb20+iG8EMBECAC8FAk53Pa0oHSBidWlsZEBteXNx
bC5jb20gd2lsbCBzdG9wIHdvcmtpbmcgc29vbgAKCRCMcY07UHLh9bU9AJ9xDK0o
xJFL9vTl9OSZC4lX0K9AzwCcCrS9cnJyz79eaRjL0s2r/CcljdyIZQQTEQIAHQUC
R6yUtAUJDTBYqAULBwoDBAMVAwIDFgIBAheAABIJEIxxjTtQcuH1B2VHUEcAAQGu
kgCffz4GUEjzXkOi71VcwgCxASTgbe0An34LPr1j9fCbrXWXO14msIADfb5piEwE
ExECAAwFAj4+o9EFgwlmALsACgkQSVDhKrJykfIk4QCfWbEeKN+3TRspe+5xKj+k
QJSammIAnjUz0xFWPlVx0f8o38qNG1bq0cU9iEwEExECAAwFAj5CggMFgwliIokA
CgkQtvXNTca6JD+WkQCgiGmnoGjMojynp5ppvMXkyUkfnykAoK79E6h8rwkSDZou
iz7nMRisH8uyiEYEEBECAAYFAj+s468ACgkQr8UjSHiDdA/2lgCg21IhIMMABTYd
p/IBiUsP/JQLiEoAnRzMywEtujQz/E9ono7H1DkebDa4iEYEEBECAAYFAj+0Q3cA
CgkQhZavqzBzTmbGwwCdFqD1frViC7WRt8GKoOS7hzNN32kAnirlbwpnT7a6NOsQ
83nk11a2dePhiEYEEBECAAYFAkNbs+oACgkQi9gubzC5S1x/dACdELKoXQKkwJN0
gZztsM7kjsIgyFMAnRRMbHQ7V39XC90OIpaPjk3a01tgiEYEExECAAYFAkTxMyYA
CgkQ9knE9GCTUwwKcQCgibak/SwhxWH1ijRhgYCo5GtM4vcAnAhtzL57wcw1Kg1X
m7nVGetUqJ7fiEwEEBECAAwFAkGBywEFgwYi2YsACgkQGFnQH2d7oexCjQCcD8sJ
NDc/mS8m8OGDUOx9VMWcnGkAnj1YWOD+Qhxo3mI/Ul9oEAhNkjcfiEwEEBECAAwF
AkGByzQFgwYi2VgACgkQgcL36+ITtpIiIwCdFVNVUB8xe8mFXoPm4d9Z54PTjpMA
niSPA/ZsfJ3oOMLKar4F0QPPrdrGiEwEEBECAAwFAkGBy2IFgwYi2SoACgkQa3Ds
2V3D9HMJqgCbBYzr5GPXOXgP88jKzmdbjweqXeEAnRss4G2G/3qD7uhTL1SPT1SH
jWUXiEwEEBECAAwFAkHQkyQFgwXUEWgACgkQfSXKCsEpp8JiVQCghvWvkPqowsw8
w7WSseTcw1tflvkAni+vLHl/DqIly0LkZYn5jzK1dpvfiEwEEBECAAwFAkIrW7oF
gwV5SNIACgkQ5hukiRXruavzEwCgkzL5QkLSypcw9LGHcFSx1ya0VL4An35nXkum
g6cCJ1NP8r2I4NcZWIrqiEwEEhECAAwFAkAqWToFgwd6S1IACgkQPKEfNJT6+GEm
XACcD+A53A5OGM7w750W11ukq4iZ9ckAnRMvndAqn3YTOxxlLPj2UPZiSgSqiEwE
EhECAAwFAkA9+roFgwdmqdIACgkQ8tdcY+OcZZyy3wCgtDcwlaq20w0cNuXFLLNe
EUaFFTwAni6RHN80moSVAdDTRkzZacJU3M5QiEwEEhECAAwFAkEOCoQFgwaWmggA
CgkQOcor9D1qil/83QCeITZ9wIo7XAMjC6y4ZWUL4m+edZsAoMOhRIRi42fmrNFu
vNZbnMGej81viEwEEhECAAwFAkKApTQFgwUj/1gACgkQBA3AhXyDn6jjJACcD1A4
UtXk84J13JQyoH9+dy24714Aniwlsso/9ndICJOkqs2j5dlHFq6oiEwEExECAAwF
Aj5NTYQFgwlXVwgACgkQLbt2v63UyTMFDACglT5G5NVKf5Mj65bFSlPzb92zk2QA
n1uc2h19/IwwrsbIyK/9POJ+JMP7iEwEExECAAwFAkHXgHYFgwXNJBYACgkQZu/b
yM2C/T4/vACfXe67xiSHB80wkmFZ2krb+oz/gBAAnjR2ucpbaonkQQgnC3GnBqmC
vNaJiEwEExECAAwFAkIYgQ4FgwWMI34ACgkQdsEDHKIxbqGg7gCfQi2HcrHn+yLF
uNlH1oSOh48ZM0oAn3hKV0uIRJphonHaUYiUP1ttWgdBiGUEExECAB0FCwcKAwQD
FQMCAxYCAQIXgAUCS3AvygUJEPPzpwASB2VHUEcAAQEJEIxxjTtQcuH1sNsAniYp
YBGqy/HhMnw3WE8kXahOOR5KAJ4xUmWPGYP4l3hKxyNK9OAUbpDVYIh7BDARAgA7
BQJCdzX1NB0AT29wcy4uLiBzaG91bGQgaGF2ZSBiZWVuIGxvY2FsISBJJ20gKnNv
KiBzdHVwaWQuLi4ACgkQOcor9D1qil/vRwCdFo08f66oKLiuEAqzlf9iDlPozEEA
n2EgvCYLCCHjfGosrkrU3WK5NFVgiI8EMBECAE8FAkVvAL9IHQBTaG91bGQgaGF2
ZSBiZWVuIGEgbG9jYWwgc2lnbmF0dXJlLCBvciBzb21ldGhpbmcgLSBXVEYgd2Fz
IEkgdGhpbmtpbmc/AAoJEDnKK/Q9aopfoPsAn3BVqKOalJeF0xPSvLR90PsRlnmG
AJ44oisY7Tl3NJbPgZal8W32fbqgbIkCIgQQAQIADAUCQYHLhQWDBiLZBwAKCRCq
4+bOZqFEaKgvEACCErnaHGyUYa0wETjj6DLEXsqeOiXad4i9aBQxnD35GUgcFofC
/nCY4XcnCMMEnmdQ9ofUuU3OBJ6BNJIbEusAabgLooebP/3KEaiCIiyhHYU5jarp
ZAh+Zopgs3Oc11mQ1tIaS69iJxrGTLodkAsAJAeEUwTPq9fHFFzC1eGBysoyFWg4
bIjz/zClI+qyTbFA5g6tRoiXTo8ko7QhY2AA5UGEg+83Hdb6akC04Z2QRErxKAqr
phHzj8XpjVOsQAdAi/qVKQeNKROlJ+iq6+YesmcWGfzeb87dGNweVFDJIGA0qY27
pTb2lExYjsRFN4Cb13NfodAbMTOxcAWZ7jAPCxAPlHUG++mHMrhQXEToZnBFE4nb
nC7vOBNgWdjUgXcpkUCkop4b17BFpR+k8ZtYLSS8p2LLz4uAeCcSm2/msJxT7rC/
FvoH8428oHincqs2ICo9zO/Ud4HmmO0O+SsZdVKIIjinGyOVWb4OOzkAlnnhEZ3o
6hAHcREIsBgPwEYVTj/9ZdC0AO44Nj9cU7awaqgtrnwwfr/o4V2gl8bLSkltZU27
/29HeuOeFGjlFe0YrDd/aRNsxbyb2O28H4sG1CVZmC5uK1iQBDiSyA7Q0bbdofCW
oQzm5twlpKWnY8Oe0ub9XP5p/sVfck4FceWFHwv+/PC9RzSl33lQ6vM2wIkCIgQT
AQIADAUCQp8KHAWDBQWacAAKCRDYwgoJWiRXzyE+D/9uc7z6fIsalfOYoLN60ajA
bQbI/uRKBFugyZ5RoaItusn9Z2rAtn61WrFhu4uCSJtFN1ny2RERg40f56pTghKr
D+YEt+Nze6+FKQ5AbGIdFsR/2bUk+ZZRSt83e14Lcb6ii/fJfzkoIox9ltkifQxq
Y7Tvk4noKu4oLSc8O1Wsfc/y0B9sYUUCmUfcnq58DEmGie9ovUslmyt5NPnveXxp
5UeaRc5Rqt9tK2B4A+7/cqENrdZJbAMSunt2+2fkYiRunAFPKPBdJBsY1sxeL/A9
aKe0viKEXQdAWqdNZKNCi8rd/oOP99/9lMbFudAbX6nL2DSb1OG2Z7NWEqgIAzjm
pwYYPCKeVz5Q8R+if9/fe5+STY/55OaI33fJ2H3v+U435VjYqbrerWe36xJItcJe
qUzW71fQtXi1CTEl3w2ch7VF5oj/QyjabLnAlHgSlkSi6p7By5C2MnbCHlCfPnIi
nPhFoRcRGPjJe9nFwGs+QblvS/Chzc2WX3s/2SWm4gEUKRX4zsAJ5ocyfa/vkxCk
SxK/erWlCPf/J1T70+i5waXDN/E3enSet/WL7h94pQKpjz8OdGL4JSBHuAVGA+a+
dknqnPF0KMKLhjrgV+L7O84FhbmAP7PXm3xmiMPriXf+el5fZZequQoIagf8rdRH
HhRJxQgI0HNknkaOqs8dtrkCDQQ+PqMdEAgA7+GJfxbMdY4wslPnjH9rF4N2qfWs
EN/lxaZoJYc3a6M02WCnHl6ahT2/tBK2w1QI4YFteR47gCvtgb6O1JHffOo2HfLm
RDRiRjd1DTCHqeyX7CHhcghj/dNRlW2Z0l5QFEcmV9U0Vhp3aFfWC4Ujfs3LU+hk
AWzE7zaD5cH9J7yv/6xuZVw411x0h4UqsTcWMu0iM1BzELqX1DY7LwoPEb/O9Rkb
f4fmLe11EzIaCa4PqARXQZc4dhSinMt6K3X4BrRsKTfozBu74F47D8Ilbf5vSYHb
uE5p/1oIDznkg/p8kW+3FxuWrycciqFTcNz215yyX39LXFnlLzKUb/F5GwADBQf+
Lwqqa8CGrRfsOAJxim63CHfty5mUc5rUSnTslGYEIOCR1BeQauyPZbPDsDD9MZ1Z
aSafanFvwFG6Llx9xkU7tzq+vKLoWkm4u5xf3vn55VjnSd1aQ9eQnUcXiL4cnBGo
TbOWI39EcyzgslzBdC++MPjcQTcA7p6JUVsP6oAB3FQWg54tuUo0Ec8bsM8b3Ev4
2LmuQT5NdKHGwHsXTPtl0klk4bQk4OajHsiy1BMahpT27jWjJlMiJc+IWJ0mghkK
Ht926s/ymfdf5HkdQ1cyvsz5tryVI3Fx78XeSYfQvuuwqp2H139pXGEkg0n6KdUO
etdZWhe70YGNPw1yjWJT1IhUBBgRAgAMBQJOdz3tBQkT+wG4ABIHZUdQRwABAQkQ
jHGNO1By4fUUmwCbBYr2+bBEn/L2BOcnw9Z/QFWuhRMAoKVgCFm5fadQ3Afi+UQl
AcOphrnJ
=443I
-----END PGP PUBLIC KEY BLOCK-----
To import the build key into your personal public GPG
keyring, use gpg --import. For example, if you have saved the
key in a file named mysql_pubkey.asc, the import command
looks like this:
shell> gpg --import mysql_pubkey.asc
gpg: key 5072E1F5: public key "MySQL Release Engineering
<mysql-build@oss.oracle.com>" imported
gpg: Total number processed: 1
gpg: imported: 1
gpg: no ultimately trusted keys found
You can also download the key from the public keyserver using
the public key id, 5072E1F5:
shell> gpg --recv-keys 5072E1F5
gpg: requesting key 5072E1F5 from hkp server keys.gnupg.net
gpg: key 5072E1F5: "MySQL Release Engineering <mysql-build@oss.oracle.
com>"
1 new user ID
gpg: key 5072E1F5: "MySQL Release Engineering <mysql-build@oss.oracle.
com>"
53 new signatures
gpg: no ultimately trusted keys found
gpg: Total number processed: 1
gpg: new user IDs: 1
gpg: new signatures: 53
If you want to import the key into your RPM configuration to
validate RPM install packages, you should be able to import
the key directly:
shell> rpm --import mysql_pubkey.asc
If you experience problems or require RPM specific
information, see Section 2.1.3.4, "Signature Checking Using
RPM."
After you have downloaded and imported the public build key,
download your desired MySQL package and the corresponding
signature, which also is available from the download page.
The signature file has the same name as the distribution file
with an .asc extension, as shown by the examples in the
following table.
Table 2.1 MySQL Package and Signature Files for Source files
File Type File Name
Distribution file mysql-standard-5.5.47-linux-i686.tar.gz
Signature file mysql-standard-5.5.47-linux-i686.tar.gz.asc
Make sure that both files are stored in the same directory
and then run the following command to verify the signature
for the distribution file:
shell> gpg --verify package_name.asc
If the downloaded package is valid, you will see a "Good
signature" similar to:
shell> gpg --verify mysql-standard-5.5.47-linux-i686.tar.gz.asc
gpg: Signature made Tue 01 Feb 2011 02:38:30 AM CST using DSA key ID 5
072E1F5
gpg: Good signature from "MySQL Release Engineering <mysql-build@oss.o
racle.com>"
The Good signature message indicates that the file signature
is valid, when compared to the signature listed on our site.
But you might also see warnings, like so:
shell> gpg --verify mysql-standard-5.5.47-linux-i686.tar.gz.asc
gpg: Signature made Wed 23 Jan 2013 02:25:45 AM PST using DSA key ID 5
072E1F5
gpg: checking the trustdb
gpg: no ultimately trusted keys found
gpg: Good signature from "MySQL Release Engineering <mysql-build@oss.o
racle.com>"
gpg: WARNING: This key is not certified with a trusted signature!
gpg: There is no indication that the signature belongs to the
owner.
Primary key fingerprint: A4A9 4068 76FC BD3C 4567 70C8 8C71 8D3B 5072
E1F5
That is normal, as they depend on your setup and
configuration. Here are explanations for these warnings:
* gpg: no ultimately trusted keys found: This means that
the specific key is not "ultimately trusted" by you or
your web of trust, which is okay for the purposes of
verifying file signatures.
* WARNING: This key is not certified with a trusted
signature! There is no indication that the signature
belongs to the owner.: This refers to your level of trust
in your belief that you possess our real public key. This
is a personal decision. Ideally, a MySQL developer would
hand you the key in person, but more commonly, you
downloaded it. Was the download tampered with? Probably
not, but this decision is up to you. Setting up a web of
trust is one method for trusting them.
See the GPG documentation for more information on how to work
with public keys.
2.1.3.3 Signature Checking Using Gpg4win for Windows
The Section 2.1.3.2, "Signature Checking Using GnuPG" section
describes how to verify MySQL downloads using GPG. That guide
also applies to Microsoft Windows, but another option is to
use a GUI tool like Gpg4win (http://www.gpg4win.org/). You
may use a different tool but our examples are based on
Gpg4win, and utilize its bundled Kleopatra GUI.
Download and install Gpg4win, and then load Kleopatra. The
dialog should look similar to:
Figure 2.1 Initial screen after loading Kleopatra
Initial screen after loading Kleopatra
Next, add the MySQL Release Engineering certificate. Do this
by clicking File, Lookup Certificates on Server. Type "Mysql
Release Engineering" into the search box and press Search.
Figure 2.2 Finding the MySQL Release Engineering certificate
Finding the MySQL Release Engineering certificate
Select the "MySQL Release Engineering" certificate. The
Fingerprint and Key-ID must be "5072E1F5", or choose
Details... to confirm the certificate is valid. Now, import
it by clicking Import. An import dialog will be displayed,
choose Okay, and this certificate will now be listed under
the Imported Certificates tab.
Next, configure the trust level for our certificate. Select
our certificate, then from the main menu select Certificates,
Change Owner Trust.... We suggest choosing I believe checks
are very accurate for our certificate, as otherwise you might
not be able to verify our signature. Select I believe checks
are very accurate and then press OK.
Figure 2.3 Changing the Trust level
Changing the Trust level
Next, verify the downloaded MySQL package file. This requires
files for both the packaged file, and the signature. The
signature file must have the same name as the packaged file
but with an appended .asc extension, as shown by the example
in the following table. The signature is linked to on the
downloads page for each MySQL product. You must create the
.asc file with this signature.
Table 2.2 MySQL Package and Signature Files for MySQL
Installer for Microsoft Windows
File Type File Name
Distribution file mysql-installer-community-5.5.47.msi
Signature file mysql-installer-community-5.5.47.msi.asc
Make sure that both files are stored in the same directory
and then run the following command to verify the signature
for the distribution file. Either drag and drop the signature
(.asc) file into Kleopatra, or load the dialog from File,
Decrypt/Verify Files..., and then choose either the .msi or
.asc file.
Figure 2.4 The Decrypt/Verify Files dialog
The Decrypt/Verify Files dialog
Click Decrypt/Verify to check the file. The two most common
results will look like the following, and although the yellow
warning looks problematic, the following means that the file
check passed with success. You may now run this installer.
Figure 2.5 The Decrypt/Verify Results: Good
The Decrypt/Verify Results: Good
Seeing a red "The signature is bad" error means the file is
invalid. Do not execute the MSI file if you see this error.
Figure 2.6 The Decrypt/Verify Results: Bad
The Decrypt/Verify Results: Bad
The Section 2.1.3.2, "Signature Checking Using GnuPG" section
explains why you probably don't see a green Good signature
result.
2.1.3.4 Signature Checking Using RPM
For RPM packages, there is no separate signature. RPM
packages have a built-in GPG signature and MD5 checksum. You
can verify a package by running the following command:
shell> rpm --checksig package_name.rpm
Example:
shell> rpm --checksig MySQL-server-5.5.47-0.glibc23.i386.rpm
MySQL-server-5.5.47-0.glibc23.i386.rpm: md5 gpg OK
Note
If you are using RPM 4.1 and it complains about (GPG) NOT OK
(MISSING KEYS: GPG#5072e1f5), even though you have imported
the MySQL public build key into your own GPG keyring, you
need to import the key into the RPM keyring first. RPM 4.1 no
longer uses your personal GPG keyring (or GPG itself).
Rather, RPM maintains a separate keyring because it is a
system-wide application and a user's GPG public keyring is a
user-specific file. To import the MySQL public key into the
RPM keyring, first obtain the key, then use rpm --import to
import the key. For example:
shell> gpg --export -a 5072e1f5 > 5072e1f5.asc
shell> rpm --import 5072e1f5.asc
Alternatively, rpm also supports loading the key directly
from a URL, and you can use this manual page:
shell> rpm --import http://dev.mysql.com/doc/refman/5.5/en/checking-gp
g-signature.html
If you need to obtain the MySQL public key, see Section
2.1.3.2, "Signature Checking Using GnuPG."
2.1.4 Installation Layouts
The installation layout differs for different installation
types (for example, native packages, binary tarballs, and
source tarballs), which can lead to confusion when managing
different systems or using different installation sources.
The individual layouts are given in the corresponding
installation type or platform chapter, as described
following. Note that the layout of installations from vendors
other than Oracle may differ from these layouts.
* Section 2.3.1, "MySQL Installation Layout on Microsoft
Windows"
* Section 2.9.1, "MySQL Layout for Source Installation"
* Section 2.2, "MySQL Installation Layout for Generic
Unix/Linux Binary Package"
* Section 2.5.1, "MySQL Installation Layout for Linux RPM
Packages"
* Section 2.4.2, "MySQL Installation Layout on OS X"
2.1.5 Compiler-Specific Build Characteristics
In some cases, the compiler used to build MySQL affects the
features available for use. The notes in this section apply
for binary distributions provided by Oracle Corporation or
that you compile yourself from source.
icc (Intel C++ Compiler) Builds
A server built with icc has these characteristics:
* SSL support is not included.
2.2 Installing MySQL on Unix/Linux Using Generic Binaries
Oracle provides a set of binary distributions of MySQL. These
include generic binary distributions in the form of
compressed tar files (files with a .tar.gz extension) for a
number of platforms, and binaries in platform-specific
package formats for selected platforms.
This section covers the installation of MySQL from a
compressed tar file binary distribution. For other
platform-specific package formats, see the other
platform-specific sections. For example, for Windows
distributions, see Section 2.3, "Installing MySQL on
Microsoft Windows."
To obtain MySQL, see Section 2.1.2, "How to Get MySQL."
MySQL compressed tar file binary distributions have names of
the form mysql-VERSION-OS.tar.gz, where VERSION is a number
(for example, 5.5.47), and OS indicates the type of operating
system for which the distribution is intended (for example,
pc-linux-i686 or winx64).
Warning
If you have previously installed MySQL using your operating
system native package management system, such as yum or
apt-get, you may experience problems installing using a
native binary. Make sure your previous MySQL installation has
been removed entirely (using your package management system),
and that any additional files, such as old versions of your
data files, have also been removed. You should also check for
configuration files such as /etc/my.cnf or the /etc/mysql
directory and delete them.
Warning
MySQL has a dependency on the libaio library. Data directory
initialization and subsequent server startup steps will fail
if this library is not installed locally. If necessary,
install it using the appropriate package manager. For
example, on Yum-based systems:
shell> yum search libaio # search for info
shell> yum install libaio # install library
Or, on APT-based systems:
shell> apt-cache search libaio # search for info
shell> apt-get install libaio1 # install library
If you run into problems and need to file a bug report,
please use the instructions in Section 1.6, "How to Report
Bugs or Problems."
On Unix, to install a compressed tar file binary
distribution, unpack it at the installation location you
choose (typically /usr/local/mysql). This creates the
directories shown in the following table.
Table 2.3 MySQL Installation Layout for Generic Unix/Linux
Binary Package
Directory Contents of Directory
bin, scripts mysqld server, client and utility programs
data Log files, databases
docs MySQL manual in Info format
man Unix manual pages
include Include (header) files
lib Libraries
share Miscellaneous support files, including error messages,
sample configuration files, SQL for database installation
sql-bench Benchmarks
Debug versions of the mysqld binary are available as
mysqld-debug. To compile your own debug version of MySQL from
a source distribution, use the appropriate configuration
options to enable debugging support. See Section 2.9,
"Installing MySQL from Source."
To install and use a MySQL binary distribution, the command
sequence looks like this:
shell> groupadd mysql
shell> useradd -r -g mysql mysql
shell> cd /usr/local
shell> tar zxvf /path/to/mysql-VERSION-OS.tar.gz
shell> ln -s full-path-to-mysql-VERSION-OS mysql
shell> cd mysql
shell> chown -R mysql .
shell> chgrp -R mysql .
shell> scripts/mysql_install_db --user=mysql
shell> chown -R root .
shell> chown -R mysql data
# Next command is optional
shell> cp support-files/my-medium.cnf /etc/my.cnf
shell> bin/mysqld_safe --user=mysql &
# Next command is optional
shell> cp support-files/mysql.server /etc/init.d/mysql.server
Note
This procedure assumes that you have root (administrator)
access to your system. Alternatively, you can prefix each
command using the sudo (Linux) or pfexec (OpenSolaris)
command.
Note
The procedure does not assign passwords to MySQL accounts. To
do so, use the instructions in Section 2.10.4, "Securing the
Initial MySQL Accounts."
A more detailed version of the preceding description for
installing a binary distribution follows.
Create a mysql User and Group
If your system does not already have a user and group to use
for running mysqld, you may need to create one. The following
commands add the mysql group and the mysql user. You might
want to call the user and group something else instead of
mysql. If so, substitute the appropriate name in the
following instructions. The syntax for useradd and groupadd
may differ slightly on different versions of Unix, or they
may have different names such as adduser and addgroup.
shell> groupadd mysql
shell> useradd -r -g mysql mysql
Note
Because the user is required only for ownership purposes, not
login purposes, the useradd command uses the -r option to
create a user that does not have login permissions to your
server host. Omit this option to permit logins for the user,
or if your useradd does not support the option.
Obtain and Unpack the Distribution
Pick the directory under which you want to unpack the
distribution and change location into it. The example here
unpacks the distribution under /usr/local. The instructions,
therefore, assume that you have permission to create files
and directories in /usr/local. If that directory is
protected, you must perform the installation as root.
shell> cd /usr/local
Obtain a distribution file using the instructions in Section
2.1.2, "How to Get MySQL." For a given release, binary
distributions for all platforms are built from the same MySQL
source distribution.
Unpack the distribution, which creates the installation
directory. Then create a symbolic link to that directory. tar
can uncompress and unpack the distribution if it has z option
support:
shell> tar zxvf /path/to/mysql-VERSION-OS.tar.gz
shell> ln -s full-path-to-mysql-VERSION-OS mysql
The tar command creates a directory named mysql-VERSION-OS.
The ln command makes a symbolic link to that directory. This
enables you to refer more easily to the installation
directory as /usr/local/mysql.
To install MySQL from a compressed tar file binary
distribution, your system must have GNU gunzip to uncompress
the distribution and a reasonable tar to unpack it. If your
tar program supports the z option, it can both uncompress and
unpack the file.
GNU tar is known to work. The standard tar provided with some
operating systems is not able to unpack the long file names
in the MySQL distribution. You should download and install
GNU tar, or if available, use a preinstalled version of GNU
tar. Usually this is available as gnutar, gtar, or as tar
within a GNU or Free Software directory, such as /usr/sfw/bin
or /usr/local/bin. GNU tar is available from
http://www.gnu.org/software/tar/.
If your tar does not have z option support, use gunzip to
unpack the distribution and tar to unpack it. Replace the
preceding tar command with the following alternative command
to uncompress and extract the distribution:
shell> gunzip < /path/to/mysql-VERSION-OS.tar.gz | tar xvf -
Perform Postinstallation Setup
The remainder of the installation process involves setting
distribution ownership and access permissions, initializing
the data directory, starting the MySQL server, and setting up
the configuration file. For instructions, see Section 2.10,
"Postinstallation Setup and Testing."
2.3 Installing MySQL on Microsoft Windows
There are several different methods to install MySQL on
Microsoft Windows.
Simple Installation Method
The simplest and recommended method is to download MySQL
Installer (for Windows) and let it install and configure all
of the MySQL products on your system. Here is how:
* Download MySQL Installer from
http://dev.mysql.com/downloads/installer/ and execute it.
Note
Unlike the standard MySQL Installer, the smaller
"web-community" version does not bundle any MySQL
applications but it will download the MySQL products you
choose to install.
* Choose the appropriate Setup Type for your system.
Typically you will choose Developer Default to install
MySQL server and other MySQL tools related to MySQL
development, helpful tools like MySQL Workbench. Or,
choose the Custom setup type to manually select your
desired MySQL products.
Note
Multiple versions of MySQL server can exist on a single
system. You can choose one or multiple versions.
* Complete the installation process by following the MySQL
Installation wizard's instructions. This will install
several MySQL products and start the MySQL server.
* MySQL is now installed. You probably configured MySQL as
a service that will automatically start MySQL server
every time you restart your system.
Note
You probably also installed other helpful MySQL products like
MySQL Workbench and MySQL Notifier on your system. Consider
loading Chapter 26, "MySQL Workbench" to check your new MySQL
server connection, and Section 2.3.4, "MySQL Notifier" to
view the connection's status. By default, these two programs
automatically start after installing MySQL.
This process also installs the MySQL Installer application on
your system, and later you can use MySQL Installer to upgrade
or reconfigure your MySQL products.
Additional Installation Information
MySQL is available for Microsoft Windows, for both 32-bit and
64-bit versions. For supported Windows platform information,
see
http://www.mysql.com/support/supportedplatforms/database.html
.
It is possible to run MySQL as a standard application or as a
Windows service. By using a service, you can monitor and
control the operation of the server through the standard
Windows service management tools. For more information, see
Section 2.3.7.7, "Starting MySQL as a Windows Service."
Generally, you should install MySQL on Windows using an
account that has administrator rights. Otherwise, you may
encounter problems with certain operations such as editing
the PATH environment variable or accessing the Service
Control Manager. Once installed, MySQL does not need to be
executed using a user with Administrator privileges.
For a list of limitations on the use of MySQL on the Windows
platform, see Section C.10.6, "Windows Platform Limitations."
In addition to the MySQL Server package, you may need or want
additional components to use MySQL with your application or
development environment. These include, but are not limited
to:
* To connect to the MySQL server using ODBC, you must have
a Connector/ODBC driver. For more information, including
installation and configuration instructions, see MySQL
Connector/ODBC Developer Guide
(http://dev.mysql.com/doc/connector-odbc/en/index.html).
Note
MySQL Installer will install and configure Connector/ODBC
for you.
* To use MySQL server with .NET applications, you must have
the Connector/Net driver. For more information, including
installation and configuration instructions, see MySQL
Connector/Net Developer Guide
(http://dev.mysql.com/doc/connector-net/en/index.html).
Note
MySQL Installer will install and configure Connector/NET
for you.
MySQL distributions for Windows can be downloaded from
http://dev.mysql.com/downloads/. See Section 2.1.2, "How to
Get MySQL."
MySQL for Windows is available in several distribution
formats, detailed here. Generally speaking, you should use
MySQL Installer. It contains more features and MySQL products
than the older MSI, is simpler to use than the Zip file, and
you need no additional tools to get MySQL up and running.
MySQL Installer automatically installs MySQL Server and
additional MySQL products, creates an options file, starts
the server, and enables you to create default user accounts.
For more information on choosing a package, see Section
2.3.2, "Choosing An Installation Package."
* Binary installer distributions. There are two different
installable distributions that come packaged as a
Microsoft Windows Installer (MSI) package that you can
install manually or automatically on your systems. The
preferred MySQL Installer package includes MySQL Server
and additional MySQL products including MySQL Workbench,
MySQL Notifier, and MySQL for Excel. MySQL Installer can
also be used to upgrade these product in the future. The
older MSI package contains all the files you need to
install and configure MySQL server, but no additional
components.
For instructions on installing MySQL using MySQL
Installer, see Section 2.3.3, "Installing MySQL on
Microsoft Windows Using MySQL Installer."
* The standard binary distribution (packaged as a Zip file)
contains all of the necessary files that you unpack into
your chosen location. This package contains all of the
files in the full Windows MSI Installer package, but does
not include an installation program.
For instructions on installing MySQL using the Zip file,
see Section 2.3.7, "Installing MySQL on Microsoft Windows
Using a noinstall Zip Archive."
* The source distribution format contains all the code and
support files for building the executables using the
Visual Studio compiler system.
For instructions on building MySQL from source on
Windows, see Section 2.9, "Installing MySQL from Source."
MySQL on Windows considerations:
* Large Table Support
If you need tables with a size larger than 4GB, install
MySQL on an NTFS or newer file system. Do not forget to
use MAX_ROWS and AVG_ROW_LENGTH when you create tables.
See Section 13.1.17, "CREATE TABLE Syntax."
* MySQL and Virus Checking Software
Virus-scanning software such as Norton/Symantec
Anti-Virus on directories containing MySQL data and
temporary tables can cause issues, both in terms of the
performance of MySQL and the virus-scanning software
misidentifying the contents of the files as containing
spam. This is due to the fingerprinting mechanism used by
the virus-scanning software, and the way in which MySQL
rapidly updates different files, which may be identified
as a potential security risk.
After installing MySQL Server, it is recommended that you
disable virus scanning on the main directory (datadir)
used to store your MySQL table data. There is usually a
system built into the virus-scanning software to enable
specific directories to be ignored.
In addition, by default, MySQL creates temporary files in
the standard Windows temporary directory. To prevent the
temporary files also being scanned, configure a separate
temporary directory for MySQL temporary files and add
this directory to the virus scanning exclusion list. To
do this, add a configuration option for the tmpdir
parameter to your my.ini configuration file. For more
information, see Section 2.3.7.2, "Creating an Option
File."
2.3.1 MySQL Installation Layout on Microsoft Windows
For MySQL 5.5 on Windows, the default installation directory
is C:\Program Files\MySQL\MySQL Server 5.5. Some Windows
users prefer to install in C:\mysql, the directory that
formerly was used as the default. However, the layout of the
subdirectories remains the same.
All of the files are located within this parent directory,
using the structure shown in the following table.
Table 2.4 Default MySQL Installation Layout for Microsoft
Windows
Directory Contents of Directory Notes
bin, scripts mysqld server, client and utility programs
%ALLUSERSPROFILE%\MySQL\MySQL Server 5.5\ Log files,
databases (Windows XP, Windows Server 2003) The Windows
system variable %ALLUSERSPROFILE% defaults to C:\Documents
and Settings\All Users\Application Data
%PROGRAMDATA%\MySQL\MySQL Server 5.5\ Log files, databases
(Vista, Windows 7, Windows Server 2008, and newer) The
Windows system variable %PROGRAMDATA% defaults to
C:\ProgramData
examples Example programs and scripts
include Include (header) files
lib Libraries
share Miscellaneous support files, including error messages,
character set files, sample configuration files, SQL for
database installation
If you install MySQL using a Windows MSI package, this
package creates and sets up the data directory that the
installed server will use, but as of MySQL 5.5.5, it also
creates a pristine "template" data directory named data under
the installation directory. This directory can be useful when
the machine will be used to run multiple instances of MySQL:
After an installation has been performed using an MSI
package, the template data directory can be copied to set up
additional MySQL instances. See Section 5.3, "Running
Multiple MySQL Instances on One Machine."
2.3.2 Choosing An Installation Package
For MySQL 5.5, there are multiple installation package
formats to choose from when installing MySQL on Windows.
Note
MySQL Installer and the "Complete Package" methods for
installing MySQL are similar, but different. The MySQL
Installer is the newer and more advanced option, and it
includes all functionality found within the "Complete
Package."
Note
Program Database (PDB) files (with file name extension pdb)
provide information for debugging your MySQL installation in
the event of a problem. These files are included in ZIP
Archive distributions (but not MSI distributions) of MySQL.
* MySQL Installer: This package has a file name similar to
mysql-installer-community-5.5.47.0.msi or
mysql-installer-commercial-5.5.47.0.msi, and utilizes
MSIs to automatically install MySQL server and other
products. It will download and apply updates to itself,
and for each of the installed products. It also
configures the additional non-server products.
The installed products are configurable, and this
includes: documentation with samples and examples,
connectors (such as C, C++, J, NET, and ODBC), MySQL
Workbench, MySQL Notifier, MySQL for Excel, and the MySQL
Server with its components.
MySQL Installer will run on all Windows platforms that
are supported by MySQL (see
http://www.mysql.com/support/supportedplatforms/database.
html).
Note
Because MySQL Installer is not a native component of
Microsoft Windows and depends on .NET, it will not work
on minimal installation options like the "Server Core"
version of Windows Server 2008.
For instructions on installing MySQL using MySQL
Installer, see Section 2.3.3, "Installing MySQL on
Microsoft Windows Using MySQL Installer."
* The Complete Package: This package has a file name
similar to mysql-5.5.47-win32.msi or
mysql-5.5.47-winx64.zip, and contains all files needed
for a complete Windows installation, including the
Configuration Wizard. This package includes optional
components such as the embedded server and benchmark
suite.
* The Noinstall Archive: This package has a file name
similar to mysql-5.5.47-win32.zip or
mysql-5.5.47-winx64.zip, and contains all the files found
in the Complete install package, with the exception of
the GUI. It also contains PDB files. This package does
not include an automated installer, and must be manually
installed and configured.
MySQL Installer is recommended for most users.
Your choice of install package affects the installation
process you must follow. If you choose to use MySQL
Installer, see Section 2.3.3, "Installing MySQL on Microsoft
Windows Using MySQL Installer." If you choose to install a
standard MSI package, see Section 2.3.5, "Installing MySQL on
Microsoft Windows Using an MSI Package." If you choose to
install a Noinstall archive, see Section 2.3.7, "Installing
MySQL on Microsoft Windows Using a noinstall Zip Archive."
2.3.3 Installing MySQL on Microsoft Windows Using MySQL Installer
MySQL Installer is an application that manages MySQL products
on Microsoft Windows. It installs, updates, removes, and
configures MySQL products, and remains on the system as its
own application. MySQL Installer is only available for
Microsoft Windows, and includes both GUI and command-line
interfaces.
The supported MySQL products include:
* MySQL server (http://dev.mysql.com/doc/) (one or multiple
versions on the same system)
* MySQL Workbench
* MySQL Connectors
(http://dev.mysql.com/doc/index-connectors.html) (.Net /
Python / ODBC / Java / C / C++)
* MySQL Notifier
* MySQL for Excel
(http://dev.mysql.com/doc/mysql-for-excel/en/index.html)
* MySQL for Visual Studio
(http://dev.mysql.com/doc/connector-net/en/connector-net-
visual-studio.html)
* MySQL Utilities and MySQL Fabric
(http://dev.mysql.com/doc/index-utils-fabric.html)
* MySQL Samples and Examples
* MySQL Documentation
* MySQL Installer is also installed and remains on the
system as its own application
* The Enterprise edition installs the Enterprise versions
of the above products, and also includes MySQL Enterprise
Backup and MySQL Enterprise Firewall
Installer package types
* Full: Bundles all of the MySQL products (including the
MySQL server). The file size is over 300MB, and its name
has the form mysql-installer-community-VERSION.N.msi
where VERSION is the MySQL Server version number such as
5.6 and N is the package number, which begins at 0.
* Web: Only contains the Installer and configuration files,
and it downloads the MySQL products you choose to
install. The size of this file is about 2MB; the name of
the file has the form
mysql-installer-community-web-VERSION.N.msi where VERSION
is the MySQL Server version number such as 5.6 and N is
the package number, which begins at 0.
* Updates: MySQL Installer can upgrade itself, so an
additional download is not requires to update MySQL
Installer.
Installer editions
* Community edition: Downloadable at
http://dev.mysql.com/downloads/installer/. It installs
the community edition of all MySQL products.
* Commercial edition: Downloadable at either My Oracle
Support (https://support.oracle.com/) (MOS) or
https://edelivery.oracle.com/. It installs the commercial
version of all MySQL products, including Workbench SE/EE,
MySQL Enterprise Backup, and MySQL Enterprise Firewall.
It also integrates with your MOS account.
Note
Entering your MOS credentials is optional when installing
bundled MySQL products, but your credentials are required
when choosing non-bundled MySQL products that MySQL
Installer must download.
For notes detailing the changes in each release of MySQL
Installer, see MySQL Installer Release Notes
(http://dev.mysql.com/doc/relnotes/mysql-installer/en/).
MySQL Installer is compatible with pre-existing
installations, and adds them to its list of installed
components. While the standard MySQL Installer is bundled
with a specific version of MySQL server, a single MySQL
Installer instance can install and manage multiple MySQL
server versions. For example, a single MySQL Installer
instance can install (and update) versions 5.5, 5.6, and 5.7
on the same host.
Note
A single host can not have both community and commercial
editions of MySQL server installed. For example, if you want
both MySQL Server 5.6 and 5.7 installed on a single host,
both must be the same edition.
MySQL Installer handles the initial configuration and set up
of the applications. For example:
1. It creates the configuration file (my.ini) that is used
to configure the MySQL Server. The values written to this
file are influenced by choices you make during the
installation process.
Note
Some definitions are host dependent. For example,
query_cache is enabled if the host has fewer than three
cores.
2. It can optionally import example databases.
3. By default, a Windows service for the MySQL server is
added.
4. It can optionally create MySQL Server user accounts with
configurable permissions based on general roles, such as
DB Administrator, DB Designer, and Backup Admin. It
optionally creates a Windows user named MysqlSys with
limited privileges, which would then run the MySQL
Server.
User accounts may also be added and configured in MySQL
Workbench.
5. Checking Show Advanced Options allows additional Logging
Options to be set. This includes defining custom file
paths for the error log, general log, slow query log
(including the configuration of seconds it requires to
execute a query), and the binary log.
MySQL Installer can optionally check for updated components
and download them for you.
2.3.3.1 MySQL Installer GUI
Installing MySQL Installer adds a link to the Start menu
under the MySQL group. Click Start, All Programs MySQL, MySQL
Installer to reload the MySQL Installer GUI.
Note
Full permissions are granted to the user executing MySQL
Installer to all generated files, such as my.ini. This does
not apply to files and directories for specific products,
such as the MySQL server data directory in %ProgramData% that
is owned by SYSTEM.
MySQL Installer requires you to accept the license agreement
before it will install MySQL products.
Figure 2.7 MySQL Installer - License Agreement
MySQL Installer - License Agreement
Installing New Packages
Choose the appropriate Setup Type for your system. This type
determines which MySQL products are initially installed on
your system, or select Custom to manually choose the
products.
* Developer: Install all products needed to develop
applications with MySQL. This is the default option.
* Server only: Only install the MySQL server.
* Client only: Only install the MySQL client products, such
as MySQL Workbench. This does not include the MySQL
server.
* Full: Install all available MySQL products.
* Custom: Manually select the MySQL products to install,
and optionally configure custom MySQL data and
installation paths.
Note
After the initial installation, you may use MySQL
Installer to manually select MySQL products to install or
remove. In other words, MySQL Installer becomes a MySQL
product management system.
Figure 2.8 MySQL Installer - Choosing a Setup Type
MySQL Installer - Choosing a Setup Type
MySQL Installer checks your system for the external
requirements (pre-requisites) required to install the
selected MySQL products. MySQL Installer can download and
install some prerequisites, but others require manual
intervention. Download and install all prerequisites that
have Status set to "Manual". Click Check to recheck if a
manual prerequisite was installed. After manually installing
those requirements, click Execute to download and install the
other prerequisites. Once finished, click Next to continue.
Figure 2.9 MySQL Installer - Check Requirements
MySQL Installer - Check Requirements
The next window lists the MySQL products that are scheduled
for installation:
Figure 2.10 MySQL Installer - Installation Progress
MySQL Installer - Installation Progress
As components are installed, their Status changes from a
progress percentage to "Complete".
After all components are installed, the next step configures
some of the recently installed MySQL products. The
Configuration Overview window displays the progress and then
loads a configuration window, if required. Our example
configures MySQL Server 5.6.x.
Configuring MySQL Server
Configuring the MySQL server begins with defining several
Type and Networking options.
Figure 2.11 MySQL Installer - Configuration Overview
MySQL Installer - Configuration Overview
Server Configuration Type
Choose the MySQL server configuration type that describes
your setup. This setting defines the amount of system
resources (memory) that will be assigned to your MySQL server
instance.
* Developer: A machine that will host many other
applications, and typically this is your personal
workstation. This option configures MySQL to use the
least amount of memory.
* Server: Several other applications will be running on
this machine, such as a web server. This option
configures MySQL to use a medium amount of memory.
* Dedicated: A machine that is dedicated to running the
MySQL server. Because no other major applications will
run on this server, such as a web server, this option
configures MySQL to use the majority of available memory.
Connectivity
Connectivity options control how the connection to MySQL is
made. Options include:
* TCP/IP: You may enable TCP/IP Networking here as
otherwise only localhost connections are allowed. Also
define the Port Number and whether to open the firewall
port for network access.
* Named Pipe: Enable and define the pipe name, similar to
using the --enable-named-pipe option.
* Shared Memory: Enable and then define the memory name,
similar to using the --shared-memory option.
Advanced Configuration
Check Show Advanced Options to set additional Logging
Options. This includes defining custom file paths for the
error log, general log, slow query log (including the
configuration of seconds it requires to execute a query), and
the binary log.
Figure 2.12 MySQL Installer - MySQL Server Configuration:
Type and Networking
MySQL Installer- MySQL Server Configuration: Type and
Networking
Accounts and Roles
Next, define your MySQL account information. Assigning a root
password is required.
Optionally, you can add additional MySQL user accounts with
predefined user roles. Each predefined role, such as "DB
Admin", are configured with their own set of privileges. For
example, the "DB Admin" role has more privileges than the "DB
Designer" role. Click the Role dropdown for a list of role
descriptions.
Note
If the MySQL Server is already installed, then you must also
enter the Current Root Password.
Figure 2.13 MySQL Installer - MySQL Server Configuration:
User Accounts and Roles
MySQL Installer - MySQL Server Configuration: User Accounts
and Roles
Figure 2.14 MySQL Installer - MySQL Server Configuration:
User Accounts and Roles: Adding a User
MySQL Installer - MySQL Server Configuration: User Accounts
and Roles: Adding a User
Windows Service
Next, configure the Windows Service details. This includes
the service name, whether the MySQL server should be loaded
at startup, and how the MySQL server Windows service is
executed.
Figure 2.15 MySQL Installer - MySQL Server Configuration:
Windows Service
MySQL Installer - MySQL Server Configuration: Windows Service
Note
When configuring Run Windows Services as ... using a Custom
User, the custom user must have privileges to log on to
Microsoft Windows as a service. The Next button will be
disabled until this user is configured with the required
privileges.
On Microsoft Windows 7, this is configured by loading the
Start Menu, Control Panel, Administrative Tools, Local
Security Policy, Local Policies, User Rights Assignment, then
Log On As A Service. Choose Add User or Group here to add the
custom user, and then OK, OK to save.
Advanced Options
The next configuration step is available if the Advanced
Configuration option was checked. This section includes
options that are related to the MySQL log files:
Figure 2.16 MySQL Installer - MySQL Server Configuration:
Logging Options
MySQL Installer - MySQL Server Configuration: Logging Options
Click Next to continue on to the final page before all of the
requested changes are applied. This Apply Server
Configuration page details the configuration steps that will
be performed.
Figure 2.17 MySQL Installer - MySQL Server Configuration:
Apply Server Configuration
MySQL Installer - MySQL Server Configuration: Apply Server
Configuration
Click Execute to execute the configuration steps. The icon
for each step toggles from white to green on success, or the
process stops on failure. Click the Log tab to view the log.
After the MySQL Installer configuration process is finished,
MySQL Installer reloads the opening page where you can
execute other installation and configuration related actions.
MySQL Installer is added to the Microsoft Windows Start menu
under the MySQL group. Opening MySQL Installer loads its
dashboard where installed MySQL products are listed, and
other MySQL Installer actions are available:
Figure 2.18 MySQL Installer - Main Dashboard
MySQL Installer - Main Dashboard
Adding MySQL Products
Click Add to add new products. This loads the Select Products
and Features page:
Figure 2.19 MySQL Installer - Select Products and Features
MySQL Installer - Select Products and Features
From here, choose the MySQL products you want to install from
the left Available Products pane, and then click the green
right arrow to queue products for installation.
Optionally, click Edit to open the product and features
search filter:
Figure 2.20 MySQL Installer - Select Products and Features
Filter
MySQL Installer - Select Products and Features Filter
For example, you might choose to include Pre-Release products
in your selections, such as a Beta product that has not yet
reached General Availability (GA) status.
Select all of the MySQL products you want to install, then
click Next to continue using the defaults, or highlight a
selected product and click Advanced Options to optionally
alter options such as the MySQL server data and installation
paths. Click Execute to execute the installation process to
install all of the selected products.
2.3.3.1.1 MySQL Product Catalog
MySQL Installer stores a MySQL product catalog. The catalog
can be updated either manually or automatically, and the
catalog change history is also available.
Manual updates
You can update the MySQL product catalog at any time by
clicking Catalog on the Installer dashboard.
Note
This also checks for a newer MySQL Installer version, and
prompts for an update if one is present.
Figure 2.21 MySQL Installer - Open the MySQL Product Catalog
MySQL Installer - Open the MySQL Product Catalog
From there, click Execute to update the product catalog.
Automatic updates
You can configure MySQL Installer to automatically update the
MySQL product catalog once per day. To enable this feature
and set the update time, click the wrench icon on the
Installer dashboard.
The next window configures the Automatic Catalog Update.
Enable or disable this feature, and also set the hour.
Figure 2.22 MySQL Installer - Configure the Catalog Scheduler
MySQL Installer - Configure the Catalog Scheduler
This option uses the Windows Task Scheduler to schedule a
task named "ManifestUpdate".
Change History
MySQL Installer tracks the change history for all of the
MySQL products. Click Catalog from the dashboard, optionally
update the catalog (or, toggle the Do not update at this time
checkbox), click Next/Execute, and then view the change
history.
Figure 2.23 MySQL Installer - Catalog Change History
MySQL Installer - Catalog Change History
2.3.3.1.2 Remove MySQL Products
MySQL Installer can also remove MySQL products from your
system. To remove a MySQL product, click Remove from the
Installer dashboard. This opens a window with a list of
installed MySQL products. Select the MySQL products you want
to remove (uninstall), and then click Execute to begin the
removal process.
Note
To select all MySQL products, click the [ ] checkbox to the
left of the Product label.
Figure 2.24 MySQL Installer - Removing Products: Select
MySQL Installer - Removing Products: Select
Figure 2.25 MySQL Installer - Removing Products: Executed
MySQL Installer - Removing Products: Executed
2.3.3.1.3 Alter MySQL Products
Use MySQL Installer to modify, configure, or upgrade your
MySQL product installations.
Upgrade
Upgradable MySQL products are listed on the main dashboard
with an arrow icon ( [wb-icon-upgrade-arrow.png] ) next to
their version number.
Figure 2.26 MySQL Installer - Upgrade a MySQL Product
MySQL Installer - Upgrade a MySQL Product
Note
The "upgrade" functionality requires a current product
catalog. This catalog is updated either manually or
automatically (daily) by enabling the Automatic Catalog
Update feature. For additional information, see Section
2.3.3.1.1, "MySQL Product Catalog."
Click Upgrade to upgrade the available products. Our example
indicates that MySQL Workbench 6.2.4 can be upgraded version
6.3.1 or 6.2.5, and MySQL server from 5.5.41 to 5.5.42.
Figure 2.27 MySQL Installer - Select Products To Upgrade
MySQL Installer - Select Products To Upgrade
If multiple upgrade versions are available (such as our MySQL
Workbench example above), select the desired version for the
upgrade in the Available Upgrades area.
Note
Optionally, click the Changes link to view the version's
release notes.
After selecting (checking) the products and versions to
upgrade, click Next to begin the upgrade process.
Figure 2.28 MySQL Installer - Apply Updates
MySQL Installer - Apply Updates
A MySQL server upgrade will also check and upgrade the
server's database. Although optional, this step is
recommended.
Figure 2.29 MySQL Installer - Check and Upgrade Database
MySQL Installer - Check and Upgrade Database
Upon completion, your upgraded products will be upgraded and
available to use. A MySQL server upgrade also restarts the
MySQL server.
Reconfigure
Some MySQL products, such as the MySQL server, include a
Reconfigure option. It opens the same configuration options
that were set when the MySQL product was installed, and is
pre-populated with the current values.
To execute, click the Reconfigure link under the Quick Action
column on the main dashboard for the MySQL product that you
want to reconfigure.
Figure 2.30 MySQL Installer - Reconfigure a MySQL Product
MySQL Installer - Reconfigure a MySQL Product
In the case of the MySQL server, this opens the familiar
configuration wizard.
Figure 2.31 MySQL Installer - Reconfiguration Wizard
MySQL Installer - Reconfiguration Wizard
Modify
Many MySQL products contain feature components that can be
added or removed. For example, Debug binaries and Client
Programs are subcomponents of the MySQL server.
The modify the features of a product, click Modify on the
main dashboard.
Figure 2.32 MySQL Installer - Modify Product Features
MySQL Installer - Modify Product Features
Click Execute to execute the modification request.
2.3.3.2 MySQL Installer Console
MySQLInstallerConsole provides functionality similar to the
GUI version of MySQL Installer, but from the command-line. It
is installed when MySQL Installer is initially executed, and
then available within the MySQL Installer directory.
Typically that is in C:\Program Files (x86)\MySQL\MySQL
Installer\, and the console must be executed with
administrative privileges.
To use, invoke the Command Prompt with administrative
privileges by choosing Start, Accessories, then right-click
on Command Prompt and choose Run as administrator. And from
the command-line, optionally change the directory to where
MySQLInstallerConsole is located:
C:\> cd "C:\Program Files (x86)\MySQL\MySQL Installer for Windows"
C:\> MySQLInstallerConsole.exe help
C:\Program Files (x86)\MySQL\MySQL Installer for Windows>MySQLInstalle
rConsole.exe help
The following commands are available:
Configure - Configures one or more of your installed programs.
Help - Provides list of available commands.
Install - Install and configure one or more available MySQL programs
.
List - Provides an interactive way to list all products available
.
Modify - Modifies the features of installed products.
Remove - Removes one or more products from your system.
Status - Shows the status of all installed products.
Update - Update the current product catalog.
Upgrade - Upgrades one or more of your installed programs.
MySQLInstallerConsole supports the following options, which
are specified on the command line:
Note
Configuration block values that contain a colon (":") must be
wrapped in double quotes. For example,
installdir="C:\MySQL\MySQL Server 5.6".
* configure [product1]:[setting]=[value];
[product2]:[setting]=[value]; [...]
Configure one or more MySQL products on your system.
Multiple setting=value pairs can be configured for each
product.
Switches include:
+ -showsettings : Displays the available options for
the selected product, by passing in the product name
after -showsettings.
+ -silent : Disable confirmation prompts.
C:\> MySQLInstallerConsole configure -showsettings server
C:\> MySQLInstallerConsole configure server:port=3307
* help [command]
Displays a help message with usage examples, and then
exits. Pass in an additional command to receive help
specific to that command.
C:\> MySQLInstallerConsole help
C:\> MySQLInstallerConsole help install
* install [product]:[features]:[config block]:[config
block]:[config block]; [...]
Install one or more MySQL products on your system.
Switches and syntax options include:
+ -type=[SetupType] : Installs a predefined set of
software. The "SetupType" can be one of the
following:
Note
Non-custom setup types can only be chosen if no
other MySQL products are installed.
o Developer: Installs a complete development
environment.
o Server: Installs a single MySQL server
o Client: Installs client programs and libraries
o Full: Installs everything
o Custom: Installs user selected products. This
is the default option.
+ -showsettings : Displays the available options for
the selected product, by passing in the product name
after -showsettings.
+ -silent : Disable confirmation prompts.
+ [config block]: One or more configuration blocks can
be specified. Each configuration block is a
semicolon separated list of key value pairs. A block
can include either a "config" or "user" type key,
where "config" is the default type if one is not
defined.
Configuration block values that contain a colon
(":") must be wrapped in double quotes. For example,
installdir="C:\MySQL\MySQL Server 5.6".
Only one "config" type block can be defined per
product. A "user" block should be defined for each
user that should be created during the product's
installation.
Note
Adding users is not supported when a product is
being reconfigured.
+ [feature]: The feature block is a semicolon
separated list of features, or '*' to select all
features.
C:\> MySQLInstallerConsole install server;5.6.25:*:port=3307;serverid=
2:type=user;username=foo;password=bar;role=DBManager
C:\> MySQLInstallerConsole install server;5.6.25;x64 -silent
An example that passes in additional configuration
blocks, broken up by ^ to fit this screen:
C:\> MySQLInstallerConsole install server;5.6.25;x64:*:type=config;ope
nfirewall=true; ^
generallog=true;binlog=true;serverid=3306;enable_tcpip=true;
port=3306;rootpasswd=pass; ^
installdir="C:\MySQL\MySQL Server 5.6":type=user;datadir="C:
\MySQL\data";username=foo;password=bar;role=DBManager
* list
Lists an interactive console where all of the available
MySQL products can be searched. Execute
MySQLInstallerConsole list to launch the console, and
enter in a substring to search.
C:\> MySQLInstallerConsole list
* modify [product1:-removelist|+addlist]
[product2:-removelist|+addlist] [...]
Modifies or displays features of a previously installed
MySQL product.
+ -silent : Disable confirmation prompts.
C:\> MySQLInstallerConsole modify server
C:\> MySQLInstallerConsole modify server:+documentation
C:\> MySQLInstallerConsole modify server:-debug
* remove [product1] [product2] [...]
Removes one ore more products from your system.
+ * : Pass in * to remove all of the MySQL products.
+ -continue : Continue the operation even if an error
occurs.
+ -silent : Disable confirmation prompts.
C:\> MySQLInstallerConsole remove *
C:\> MySQLInstallerConsole remove server
* status
Provides a quick overview of the MySQL products that are
installed on the system. Information includes product
name and version, architecture, date installed, and
install location.
C:\> MySQLInstallerConsole status
* upgrade [product1:version] [product2:version], [...]
Upgrades one or more products on your system. Syntax
options include:
+ * : Pass in * to upgrade all products to the latest
version, or pass in specific products.
+ ! : Pass in ! as a version number to upgrade the
MySQL product to its latest version.
+ -silent : Disable confirmation prompts.
C:\> MySQLInstallerConsole upgrade *
C:\> MySQLInstallerConsole upgrade workbench:6.3.5
C:\> MySQLInstallerConsole upgrade workbench:!
C:\> MySQLInstallerConsole upgrade workbench:6.3.5 excel:1.3.2
* update
Downloads the latest MySQL product catalog to your
system. On success, the download catalog will be applied
the next time either MySQLInstaller or
MySQLInstallerConsole is executed.
C:\> MySQLInstallerConsole update
Note
The Automatic Catalog Update GUI option executes this
command from the Windows Task Scheduler.
2.3.4 MySQL Notifier
The MySQL Notifier is a tool that enables you to monitor and
adjust the status of your local and remote MySQL Server
instances through an indicator that resides in the system
tray. The MySQL Notifier also gives quick access to several
MySQL GUI tools (such as MySQL Workbench) through its context
menu.
The MySQL Notifier is installed by MySQL Installer, and (by
default) will start-up when Microsoft Windows is started.
Note
To install, download and execute the MySQL Installer
(http://dev.mysql.com/downloads/installer/), be sure the
MySQL Notifier product is selected, then proceed with the
installation. See the MySQL Installer manual for additional
details.
For notes detailing the changes in each release of MySQL
Notifier, see the MySQL Notifier Release Notes
(http://dev.mysql.com/doc/relnotes/mysql-notifier/en/).
Visit the MySQL Notifier forum
(http://forums.mysql.com/list.php?173) for additional MySQL
Notifier help and support.
Features include:
* Start, Stop, and Restart instances of the MySQL Server.
* Automatically detects (and adds) new MySQL Server
services. These are listed under Manage Monitored Items,
and may also be configured.
* The Tray icon changes, depending on the status. It's
green if all monitored MySQL Server instances are
running, or red if at least one service is stopped. The
Update MySQL Notifier tray icon based on service status
option, which dictates this behavior, is enabled by
default for each service.
* Links to other applications like MySQL Workbench, MySQL
Installer, and the MySQL Utilities. For example, choosing
Configure Instance will load the MySQL Workbench Server
Administration window for that particular instance.
* If MySQL Workbench is also installed, then the Configure
Instance and SQL Editor options are available for local
(but not remote) MySQL instances.
* Monitoring of both local and remote MySQL instances.
Note
Remote monitoring is available since MySQL Notifier 1.1.0.
The MySQL Notifier resides in the system tray and provides
visual status information for your MySQL Server instances. A
green icon is displayed at the top left corner of the tray
icon if the current MySQL Server is running, or a red icon if
the service is stopped.
The MySQL Notifier automatically adds discovered MySQL
Services on the local machine, and each service is saved and
configurable. By default, the Automatically add new services
whose name contains option is enabled and set to mysql.
Related Notifications Options include being notified when new
services are either discovered or experience status changes,
and are also enabled by default. And uninstalling a service
will also remove the service from the MySQL Notifier.
Note
The Automatically add new services whose name contains option
default changed from ".*mysqld.*" to "mysql" in Notifier
1.1.0.
Clicking the system tray icon will reveal several options, as
seen in the screenshots below:
The Service Instance menu is the main MySQL Notifier window,
and enables you to Stop, Start, and Restart the MySQL Server.
Figure 2.33 MySQL Notifier Service Instance menu
MySQL Notifier Service Instance menu
The Actions menu includes several links to external
applications (if they are installed), and a Refresh Status
option to manually refresh the status of all monitored
services (in both local and remote computers) and MySQL
instances.
Note
The main menu will not show the Actions menu when there are
no services being monitored by MySQL Notifier.
Note
The Refresh Status feature is available since MySQL Notifier
1.1.0.
Figure 2.34 MySQL Notifier Actions menu
MySQL Notifier Actions menu
The Actions, Options menu configures MySQL Notifier and
includes options to:
* Use colorful status icons: Enables a colorful style of
icons for the tray of the MySQL Notifier.
* Run at Windows Startup: Allows the application to be
loaded when Microsoft Windows starts.
* Automatically Check For Updates Every # Weeks: Checks for
a new version of MySQL Notifier, and runs this check
every # weeks.
* Automatically add new services whose name contains: The
text used to filter services and add them automatically
to the monitored list of the local computer running MySQL
Notifier, and on remote computers already monitoring
Windows services. monitored services, and also filters
the list of the Microsoft Windows services for the Add
New Service dialog.
Prior to version 1.1.0, this option was named
"Automatically add new services that match this pattern."
* Notify me when a service is automatically added: Will
display a balloon notification from the taskbar when a
newly discovered service is added to the monitored
services list.
* Notify me when a service changes status: Will display a
balloon notification from the taskbar when a monitored
service changes its status.
Figure 2.35 MySQL Notifier Options menu
MySQL Notifier Options menu
The Actions, Manage Monitored Items menu enables you to
configure the monitored services and MySQL instances. First,
with the Services tab open:
Figure 2.36 MySQL Notifier Manage Services menu
MySQL Notifier Manage Services menu
The Instances tab is similar:
Figure 2.37 MySQL Notifier Manage Instances menu
MySQL Notifier Manage Instances menu
Adding a service or instance (after clicking Add in the
Manage Monitored Items window) enables you to select a
running Microsoft Windows service or instance connection, and
configure MySQL Notifier to monitor it. Add a new service or
instance by clicking service name from the list, then OK to
accept. Multiple services and instances may be selected.
Figure 2.38 MySQL Notifier Adding new services
MySQL Notifier Adding new services
And instances:
Figure 2.39 MySQL Notifier Adding new instances
MySQL Notifier Adding new instances
Note
The Instances tab available since MySQL Notifier 1.1.0.
2.3.4.1 Remote monitoring set up and installation instructions
The MySQL Notifier uses Windows Management Instrumentation
(WMI) to manage and monitor services in remote computers
running Windows XP or later. This guide explains how it
works, and how to set up your system to monitor remote MySQL
instances.
Note
Remote monitoring is available since MySQL Notifier 1.1.0.
In order to configure WMI, it is important to understand that
the underlying Distributed Component Object Model (DCOM)
architecture is doing the WMI work. Specifically, MySQL
Notifier is using asynchronous notification queries on remote
Microsoft Windows hosts as .NET events. These events send an
asynchronous callback to the computer running the MySQL
Notifier so it knows when a service status has changed on the
remote computer. Asynchronous notifications offer the best
performance compared to semisynchronous notifications or
synchronous notifications that use timers.
Asynchronous notifications requires the remote computer to
send a callback to the client computer (thus opening a
reverse connection), so the Windows Firewall and DCOM
settings must be properly configured for the communication to
function properly.
Figure 2.40 MySQL Notifier Distributed Component Object Model
(DCOM)
MySQL Notifier Distributed Component Object Model (DCOM)
Most of the common errors thrown by asynchronous WMI
notifications are related to Windows Firewall blocking the
communication, or to DCOM / WMI settings not being set up
properly. For a list of common errors with solutions, see
Section 2.3.4.1, "."
The following steps are required to make WMI function. These
steps are divided between two machines. A single host
computer that runs MySQL Notifier (Computer A), and multiple
remote machines that are being monitored (Computer B).
Computer running MySQL Notifier (Computer A)
1. Allow for remote administration by either editing the
Group Policy Editor, or using NETSH:
Using the Group Policy Editor:
a. Click Start, click Run, type GPEDIT.MSC, and then
click OK.
b. Under the Local Computer Policy heading,
double-click Computer Configuration.
c. Double-click Administrative Templates, then Network,
Network Connections, and then Windows Firewall.
d. If the computer is in the domain, then double-click
Domain Profile; otherwise, double-click Standard
Profile.
e. Click Windows Firewall: Allow inbound remote
administration exception.
f. On the Action menu either select Edit, or
double-click the selection from the previous step.
g. Check the Enabled radio button, and then click OK.
Using the NETSH command:
Note
The "netsh firewall" command is deprecated as of
Microsoft Server 2008 and Vista, and replaced with "netsh
advfirewall firewall".
a. Open a command prompt window with Administrative
rights (you can right-click the Command Prompt icon
and click Run as Administrator).
b. Execute the following command:
NETSH advfirewall firewall set service RemoteAdmin enable
2. Open the DCOM port TCP 135:
a. Open a command prompt window with Administrative
rights (you can right-click the Command Prompt icon
and click Run as Administrator) .
b. Execute the following command:
NETSH advfirewall firewall add portopening protocol=tcp port=135 name=
DCOM_TCP135
3. Add the client application which contains the sink for
the callback (MySqlNotifier.exe) to the Windows Firewall
Exceptions List (use either the Windows Firewall
configuration or NETSH):
Using the Windows Firewall configuration:
a. In the Control Panel, double-click Windows Firewall.
b. In the Windows Firewall window's left panel, click
Allow a program or feature through Windows Firewall.
c. In the Allowed Programs window, click Change
Settings.
d. If MySqlNotifier.exe is in the Allowed programs and
features list, make sure it is checked for the type
of networks the computer connects to (Private,
Public or both).
e. If MySqlNotifier.exe is not in the list, click Allow
another program....
f. In the Add a Program window, select the
MySqlNotifier.exe if it exists in the Programs list,
otherwise click Browse... and go to the directory
where MySqlNotifier.exe was installed to select it,
then click Add.
g. Make sure MySqlNotifier.exe is checked for the type
of networks the computer connects to (Private,
Public or both).
Using the NETSH command:
a. Open a command prompt window with Administrative
rights (you can right-click the Command Prompt icon
and click Run as Administrator).
b. Execute the following command, where you change
"[YOUR_INSTALL_DIRECTORY]":
NETSH advfirewall firewall add allowedprogram program=[YOUR_INSTALL_DI
RECTORY]\MySqlNotifier.exe name=MySqlNotifier
4. If Computer B is either a member of WORKGROUP or is in a
different domain that is untrusted by Computer A, then
the callback connection (Connection 2) is created as an
Anonymous connection. To grant Anonymous connections DCOM
Remote Access permissions:
a. Click Start, click Run, type DCOMCNFG, and then
click OK.
b. In the Component Services dialog box, expand
Component Services, expand Computers, and then
right-click My Computer and click Properties.
c. In the My Computer Properties dialog box, click the
COM Security tab.
d. Under Access Permissions, click Edit Limits.
e. In the Access Permission dialog box, select
ANONYMOUS LOGON name in the Group or user names box.
In the Allow column under Permissions for User,
select Remote Access, and then click OK.
Monitored Remote Computer (Computer B)
If the user account that is logged into the computer running
the MySQL Notifier (Computer A) is a local administrator on
the remote computer (Computer B), such that the same account
is an administrator on Computer B, you can skip to the "Allow
for remote administration" step.
Setting DCOM security to allow a non-administrator user to
access a computer remotely:
1. Grant "DCOM remote launch" and activation permissions for
a user or group:
a. Click Start, click Run, type DCOMCNFG, and then
click OK.
b. In the Component Services dialog box, expand
Component Services, expand Computers, and then
right-click My Computer and click Properties.
c. In the My Computer Properties dialog box, click the
COM Security tab.
d. Under Access Permissions, click Edit Limits.
e. In the Launch Permission dialog box, follow these
steps if your name or your group does not appear in
the Groups or user names list:
i. In the Launch Permission dialog box, click Add.
ii. In the Select Users, Computers, or Groups
dialog box, add your name and the group in the
"Enter the object names to select" box, and
then click OK.
f. In the Launch Permission dialog box, select your
user and group in the Group or user names box. In
the Allow column under Permissions for User, select
Remote Launch, select Remote Activation, and then
click OK.
Grant DCOM remote access permissions:
a. Click Start, click Run, type DCOMCNFG, and then
click OK.
b. In the Component Services dialog box, expand
Component Services, expand Computers, and then
right-click My Computer and click Properties.
c. In the My Computer Properties dialog box, click the
COM Security tab.
d. Under Access Permissions, click Edit Limits.
e. In the Access Permission dialog box, select
ANONYMOUS LOGON name in the Group or user names box.
In the Allow column under Permissions for User,
select Remote Access, and then click OK.
2. Allowing non-administrator users access to a specific WMI
namespace:
a. In the Control Panel, double-click Administrative
Tools.
b. In the Administrative Tools window, double-click
Computer Management.
c. In the Computer Management window, expand the
Services and Applications tree and double-click the
WMI Control.
d. Right-click the WMI Control icon and select
Properties.
e. In the WMI Control Properties window, click the
Security tab.
f. In the Security tab, select the namespace and click
Security.
g. Locate the appropriate account and check Remote
Enable in the Permissions list.
3. Allow for remote administration by either editing the
Group Policy Editor or using NETSH:
Using the Group Policy Editor:
a. Click Start, click Run, type GPEDIT.MSC, and then
click OK.
b. Under the Local Computer Policy heading,
double-click Computer Configuration.
c. Double-click Administrative Templates, then Network,
Network Connections, and then Windows Firewall.
d. If the computer is in the domain, then double-click
Domain Profile; otherwise, double-click Standard
Profile.
e. Click Windows Firewall: Allow inbound remote
administration exception.
f. On the Action menu either select Edit, or
double-click the selection from the previous step.
g. Check the Enabled radio button, and then click OK.
Using the NETSH command:
a. Open a command prompt window with Administrative
rights (you can right-click the Command Prompt icon
and click Run as Administrator).
b. Execute the following command:
NETSH advfirewall firewall set service RemoteAdmin enable
4. Now, be sure the user you are logging in with uses the
Name value and not the Full Name value:
a. In the Control Panel, double-click Administrative
Tools.
b. In the Administrative Tools window, double-click
Computer Management.
c. In the Computer Management window, expand the System
Tools then Local Users and Groups.
d. Click the Users node, and on the right side panel
locate your user and make sure it uses the Name
value to connect, and not the Full Name value.
5. If the remote computer is running on Windows XP
Professional, make sure that remote logins are not being
forcefully changed to the guest account user (also known
as ForceGuest), which is enabled by default on computers
that are not attached to a domain.
a. Click Start, click Run, type SECPOL.MSC, and then
click OK.
b. Under the Local Policies node, double-click Security
Options.
c. Select Network Access: Sharing and security model
for local accounts and save.
Common Errors
* 0x80070005
+ DCOM Security was not configured properly (see
Computer B, the Setting DCOM security... step).
+ The remote computer (Computer B) is a member of
WORKGROUP or is in a domain that is untrusted by the
client computer (Computer A) (see Computer A, the
Grant Anonymous connections DCOM Remote Access
permissions step).
* 0x8007000E
+ The remote computer (Computer B) is a member of
WORKGROUP or is in a domain that is untrusted by the
client computer (Computer A) (see Computer A, the
Grant Anonymous connections DCOM Remote Access
permissions step).
* 0x80041003
+ Access to the remote WMI namespace was not
configured properly (see Computer B, the Allowing
non-administrator users access to a specific WMI
namespace step).
* 0x800706BA
+ The DCOM port is not open on the client computers
(Computer A) firewall. See the Open the DCOM port
TCP 135 step for Computer A.
+ The remote computer (Computer B) is inaccessible
because its network location is set to Public. Make
sure you can access it through the Windows Explorer.
2.3.5 Installing MySQL on Microsoft Windows Using an MSI Package
The MSI package is designed to install and configure MySQL in
such a way that you can immediately get started using MySQL.
The MySQL Installation Wizard and MySQL Configuration Wizard
are available in the Complete install package, which is
recommended for most standard MySQL installations. Exceptions
include users who need to install multiple instances of MySQL
on a single server host and advanced users who want complete
control of server configuration.
* For information on installing using the GUI MSI installer
process, see Section 2.3.5.1, "Using the MySQL
Installation Wizard."
* For information on installing using the command line
using the MSI package, see Section 2.3.5.2, "Automating
MySQL Installation on Microsoft Windows Using the MSI
Package."
* If you have previously installed MySQL using the MSI
package and want to remove MySQL, see Section 2.3.5.3,
"Removing MySQL When Installed from the MSI Package."
The workflow sequence for using the installer is shown in the
figure below:
Figure 2.41 Installation Workflow for Windows Using MSI
Installer
Installation Workflow for Windows using MSI Installer
Note
Microsoft Windows XP and later include a firewall which
specifically blocks ports. If you plan on using MySQL through
a network port then you should open and create an exception
for this port before performing the installation. To check
and if necessary add an exception to the firewall settings:
1. First ensure that you are logged in as an Administrator
or a user with Administrator privileges.
2. Go to the Control Panel, and double click the Windows
Firewall icon.
3. Choose the Allow a program through Windows Firewall
option and click the Add port button.
4. Enter MySQL into the Name text box and 3306 (or the port
of your choice) into the Port number text box.
5. Also ensure that the TCP protocol radio button is
selected.
6. If you wish, you can also limit access to the MySQL
server by choosing the Change scope button.
7. Confirm your choices by clicking the OK button.
Additionally, when running the MySQL Installation Wizard on
Windows Vista or newer, ensure that you are logged in as a
user with administrative rights.
Note
When using Windows Vista or newer, you may want to disable
User Account Control (UAC) before performing the
installation. If you do not do so, then MySQL may be
identified as a security risk, which will mean that you need
to enable MySQL. You can disable the security checking by
following these instructions:
1. Open Control Panel.
2. Under the User Accounts and Family Safety, select Add or
remove user accounts.
3. Click the Got to the main User Accounts page link.
4. Click on Turn User Account Control on or off. You may be
prompted to provide permission to change this setting.
Click Continue.
5. Deselect or uncheck the check box next to Use User
Account Control (UAC) to help protect your computer.
Click OK to save the setting.
You will need to restart to complete the process. Click
Restart Now to reboot the machine and apply the changes. You
can then follow the instructions below for installing
Windows.
2.3.5.1 Using the MySQL Installation Wizard
MySQL Installation Wizard is an installer for the MySQL
server that uses the latest installer technologies for
Microsoft Windows. The MySQL Installation Wizard, in
combination with the MySQL Configuration Wizard, enables a
user to install and configure a MySQL server that is ready
for use immediately after installation.
The MySQL Installation Wizard is the standard installer for
all MySQL server distributions, version 4.1.5 and higher.
Users of previous versions of MySQL need to shut down and
remove their existing MySQL installations manually before
installing MySQL with the MySQL Installation Wizard. See
Section 2.3.5.1.6, "Upgrading MySQL with the Installation
Wizard," for more information on upgrading from a previous
version.
Microsoft has included an improved version of their Microsoft
Windows Installer (MSI) in the recent versions of Windows.
MSI has become the de-facto standard for application
installations on Windows 2000, Windows XP, and Windows Server
2003. The MySQL Installation Wizard makes use of this
technology to provide a smoother and more flexible
installation process.
The Microsoft Windows Installer Engine was updated with the
release of Windows XP; those using a previous version of
Windows can reference this Microsoft Knowledge Base article
(http://support.microsoft.com/default.aspx?scid=kb;EN-US;2925
39) for information on upgrading to the latest version of the
Windows Installer Engine.
In addition, Microsoft has introduced the WiX (Windows
Installer XML) toolkit recently. This is the first highly
acknowledged Open Source project from Microsoft. We have
switched to WiX because it is an Open Source project and it
enables us to handle the complete Windows installation
process in a flexible manner using scripts.
Improving the MySQL Installation Wizard depends on the
support and feedback of users like you. If you find that the
MySQL Installation Wizard is lacking some feature important
to you, or if you discover a bug, please report it in our
bugs database using the instructions given in Section 1.6,
"How to Report Bugs or Problems."
2.3.5.1.1 Downloading and Starting the MySQL Installation Wizard
The MySQL installation packages can be downloaded from
http://dev.mysql.com/downloads/. If the package you download
is contained within a Zip archive, you need to extract the
archive first.
Note
If you are installing on Windows Vista or newer, it is best
to open a network port before beginning the installation. To
do this, first ensure that you are logged in as an
Administrator, go to the Control Panel, and double-click the
Windows Firewall icon. Choose the Allow a program through
Windows Firewall option and click the Add port button. Enter
MySQL into the Name text box and 3306 (or the port of your
choice) into the Port number text box. Also ensure that the
TCP protocol radio button is selected. If you wish, you can
also limit access to the MySQL server by choosing the Change
scope button. Confirm your choices by clicking the OK button.
If you do not open a port prior to installation, you cannot
configure the MySQL server immediately after installation.
Additionally, when running the MySQL Installation Wizard on
Windows Vista or newer, ensure that you are logged in as a
user with administrative rights.
The process for starting the wizard depends on the contents
of the installation package you download. If there is a
setup.exe file present, double-click it to start the
installation process. If there is an .msi file present,
double-click it to start the installation process.
2.3.5.1.2 Choosing an Install Type
There are three installation types available: Typical,
Complete, and Custom.
The Typical installation type installs the MySQL server, the
mysql command-line client, and the command-line utilities.
The command-line clients and utilities include mysqldump,
myisamchk, and several other tools to help you manage the
MySQL server.
The Complete installation type installs all components
included in the installation package. The full installation
package includes components such as the embedded server
library, the benchmark suite, support scripts, and
documentation.
The Custom installation type gives you complete control over
which packages you wish to install and the installation path
that is used. See Section 2.3.5.1.3, "The Custom Install
Dialog," for more information on performing a custom install.
If you choose the Typical or Complete installation types and
click the Next button, you advance to the confirmation screen
to verify your choices and begin the installation. If you
choose the Custom installation type and click the Next
button, you advance to the custom installation dialog,
described in Section 2.3.5.1.3, "The Custom Install Dialog."
2.3.5.1.3 The Custom Install Dialog
If you wish to change the installation path or the specific
components that are installed by the MySQL Installation
Wizard, choose the Custom installation type.
A tree view on the left side of the custom install dialog
lists all available components. Components that are not
installed have a red X icon; components that are installed
have a gray icon. To change whether a component is installed,
click that component's icon and choose a new option from the
drop-down list that appears.
You can change the default installation path by clicking the
Change... button to the right of the displayed installation
path.
After choosing your installation components and installation
path, click the Next button to advance to the confirmation
dialog.
2.3.5.1.4 The Confirmation Dialog
Once you choose an installation type and optionally choose
your installation components, you advance to the confirmation
dialog. Your installation type and installation path are
displayed for you to review.
To install MySQL if you are satisfied with your settings,
click the Install button. To change your settings, click the
Back button. To exit the MySQL Installation Wizard without
installing MySQL, click the Cancel button.
The final screen of the installer provides a summary of the
installation and gives you the option to launch the MySQL
Configuration Wizard, which you can use to create a
configuration file, install the MySQL service, and configure
security settings.
2.3.5.1.5 Changes Made by MySQL Installation Wizard
Once you click the Install button, the MySQL Installation
Wizard begins the installation process and makes certain
changes to your system which are described in the sections
that follow.
Changes to the Registry
The MySQL Installation Wizard creates one Windows registry
key in a typical install situation, located in
HKEY_LOCAL_MACHINE\SOFTWARE\MySQL AB.
The MySQL Installation Wizard creates a key named after the
release series of the server that is being installed, such as
MySQL Server 5.5. It contains two string values, Location and
Version. The Location string contains the path to the
installation directory. In a default installation it contains
C:\Program Files\MySQL\MySQL Server 5.5\. The Version string
contains the release number. For example, for an installation
of MySQL Server 5.5.47, the key contains a value of 5.5.47.
These registry keys are used to help external tools identify
the installed location of the MySQL server, preventing a
complete scan of the hard-disk to determine the installation
path of the MySQL server. The registry keys are not required
to run the server, and if you install MySQL using the
noinstall Zip archive, the registry keys are not created.
Changes to the Start Menu
The MySQL Installation Wizard creates a new entry in the
Windows Start menu under a common MySQL menu heading named
after the release series of MySQL that you have installed.
For example, if you install MySQL 5.5, the MySQL Installation
Wizard creates a MySQL Server 5.5 section in the Start menu.
The following entries are created within the new Start menu
section:
* MySQL Command-Line Client: This is a shortcut to the
mysql command-line client and is configured to connect as
the root user. The shortcut prompts for a root user
password when you connect.
* MySQL Server Instance Config Wizard: This is a shortcut
to the MySQL Configuration Wizard. Use this shortcut to
configure a newly installed server, or to reconfigure an
existing server.
* MySQL Documentation: This is a link to the MySQL server
documentation that is stored locally in the MySQL server
installation directory.
Changes to the File System
The MySQL Installation Wizard by default installs the MySQL
5.5 server to C:\Program Files\MySQL\MySQL Server 5.5, where
Program Files is the default location for applications in
your system, and 5.5 is the release series of your MySQL
server. This is the recommended location for the MySQL
server, replacing the former default location C:\mysql.
By default, all MySQL applications are stored in a common
directory at C:\Program Files\MySQL, where Program Files is
the default location for applications in your Windows
installation. A typical MySQL installation on a developer
machine might look like this:
C:\Program Files\MySQL\MySQL Server 5.5
C:\Program Files\MySQL\MySQL Workbench 5.1 OSS
This approach makes it easier to manage and maintain all
MySQL applications installed on a particular system.
The default location of the data directory is the AppData
directory configured for the user that installed the MySQL
application.
2.3.5.1.6 Upgrading MySQL with the Installation Wizard
The MySQL Installation Wizard can perform server upgrades
automatically using the upgrade capabilities of MSI. That
means you do not need to remove a previous installation
manually before installing a new release. The installer
automatically shuts down and removes the previous MySQL
service before installing the new version.
Automatic upgrades are available only when upgrading between
installations that have the same major and minor version
numbers. For example, you can upgrade automatically from
MySQL 5.5.5 to MySQL 5.5.6, but not from MySQL 5.1 to MySQL
5.5.
See Section 2.3.10, "Upgrading MySQL on Windows."
2.3.5.2 Automating MySQL Installation on Microsoft Windows Using
the MSI Package
The Microsoft Installer (MSI) supports a both a quiet and a
passive mode that can be used to install MySQL automatically
without requiring intervention. You can use this either in
scripts to automatically install MySQL or through a terminal
connection such as Telnet where you do not have access to the
standard Windows user interface. The MSI packages can also be
used in combination with Microsoft's Group Policy system
(part of Windows Server 2003 and Windows Server 2008) to
install MySQL across multiple machines.
To install MySQL from one of the MSI packages automatically
from the command line (or within a script), you need to use
the msiexec.exe tool. For example, to perform a quiet
installation (which shows no dialog boxes or progress):
shell> msiexec /i mysql-5.5.47.msi /quiet
The /i indicates that you want to perform an installation.
The /quiet option indicates that you want no interactive
elements.
To provide a dialog box showing the progress during
installation, and the dialog boxes providing information on
the installation and registration of MySQL, use /passive mode
instead of /quiet:
shell> msiexec /i mysql-5.5.47.msi /passive
Regardless of the mode of the installation, installing the
package in this manner performs a 'Typical' installation, and
installs the default components into the standard location.
You can also use this method to uninstall MySQL by using the
/uninstall or /x options:
shell> msiexec /x mysql-5.5.47.msi /uninstall
To install MySQL and configure a MySQL instance from the
command line, see Section 2.3.6.13, "MySQL Server Instance
Config Wizard: Creating an Instance from the Command Line."
For information on using MSI packages to install software
automatically using Group Policy, see How to use Group Policy
to remotely install software in Windows Server 2003
(http://support.microsoft.com/kb/816102).
2.3.5.3 Removing MySQL When Installed from the MSI Package
To uninstall a MySQL where you have used the MSI packages,
you must use the Add/Remove Programs tool within Control
Panel. To do this:
1. Right-click the start menu and choose Control Panel.
2. If the Control Panel is set to category mode (you will
see Pick a category at the top of the Control Panel
window), double-click Add or Remove Programs. If the
Control is set to classic mode, double-click the Add or
Remove Programs icon.
3. Find MySQL in the list of installed software. MySQL
Server is installed against release series numbers (MySQL
5.1, MySQL 5.5, etc.). Select the version that you want
to remove and click Remove.
4. You will be prompted to confirm the removal. Click Yes to
remove MySQL.
When MySQL is removed using this method, only the installed
components are removed. Any database information (including
the tables and data), import or export files, log files, and
binary logs produced during execution are kept in their
configured location.
If you try to install MySQL again the information will be
retained and you will be prompted to enter the password
configured with the original installation.
If you want to delete MySQL completely:
* Delete the associated data directory. On Windows XP and
Windows Server 2003, the default data directory is the
configured AppData directory, which is C:\Documents and
Settings\All Users\Application Data\MySQL by default.
* On Windows 7 and Windows Server 2008, the default data
directory location is C:\ProgramData\Mysql.
Note
The C:\ProgramData directory is hidden by default. You
must change your folder options to view the hidden file.
Choose Organize, Folder and search options, Show hidden
folders.
2.3.6 MySQL Server Instance Configuration Wizard
The MySQL Server Instance Configuration Wizard helps automate
the process of configuring your server. It creates a custom
MySQL configuration file (my.ini or my.cnf) by asking you a
series of questions and then applying your responses to a
template to generate the configuration file that is tuned to
your installation.
The MySQL Server Instance Configuration Wizard is included
with the MySQL 5.5 server. The MySQL Server Instance
Configuration Wizard is only available for Windows.
2.3.6.1 Starting the MySQL Server Instance Configuration Wizard
The MySQL Server Instance Configuration Wizard is normally
started as part of the installation process. You should only
need to run the MySQL Server Instance Configuration Wizard
again when you need to change the configuration parameters of
your server.
If you chose not to open a port prior to installing MySQL on
Windows Vista or newer, you can choose to use the MySQL
Server Configuration Wizard after installation. However, you
must open a port in the Windows Firewall. To do this see the
instructions given in Section 2.3.5.1.1, "Downloading and
Starting the MySQL Installation Wizard." Rather than opening
a port, you also have the option of adding MySQL as a program
that bypasses the Windows Firewall. One or the other option
is sufficient---you need not do both. Additionally, when
running the MySQL Server Configuration Wizard on Windows
Vista or newer, ensure that you are logged in as a user with
administrative rights.
MySQL Server Instance Configuration Wizard
You can launch the MySQL Configuration Wizard by clicking the
MySQL Server Instance Config Wizard entry in the MySQL
section of the Windows Start menu.
Alternatively, you can navigate to the bin directory of your
MySQL installation and launch the MySQLInstanceConfig.exe
file directly.
The MySQL Server Instance Configuration Wizard places the
my.ini file in the installation directory for the MySQL
server. This helps associate configuration files with
particular server instances.
To ensure that the MySQL server knows where to look for the
my.ini file, an argument similar to this is passed to the
MySQL server as part of the service installation:
--defaults-file="C:\Program Files\MySQL\MySQL Server 5.5\my.ini"
Here, C:\Program Files\MySQL\MySQL Server 5.5 is replaced
with the installation path to the MySQL Server. The
--defaults-file option instructs the MySQL server to read the
specified file for configuration options when it starts.
Apart from making changes to the my.ini file by running the
MySQL Server Instance Configuration Wizard again, you can
modify it by opening it with a text editor and making any
necessary changes. You can also modify the server
configuration with the
http://www.mysql.com/products/administrator/ utility. For
more information about server configuration, see Section
5.1.3, "Server Command Options."
MySQL clients and utilities such as the mysql and mysqldump
command-line clients are not able to locate the my.ini file
located in the server installation directory. To configure
the client and utility applications, create a new my.ini file
in the Windows installation directory (for example,
C:\WINDOWS).
Under Windows Server 2003, Windows Server 2000, Windows XP,
and Windows Vista, MySQL Server Instance Configuration Wizard
will configure MySQL to work as a Windows service. To start
and stop MySQL you use the Services application that is
supplied as part of the Windows Administrator Tools.
2.3.6.2 Choosing a Maintenance Option
If the MySQL Server Instance Configuration Wizard detects an
existing configuration file, you have the option of either
reconfiguring your existing server, or removing the server
instance by deleting the configuration file and stopping and
removing the MySQL service.
To reconfigure an existing server, choose the Re-configure
Instance option and click the Next button. Any existing
configuration file is not overwritten, but renamed (within
the same directory) using a timestamp (Windows) or sequential
number (Linux). To remove the existing server instance,
choose the Remove Instance option and click the Next button.
If you choose the Remove Instance option, you advance to a
confirmation window. Click the Execute button. The MySQL
Server Configuration Wizard stops and removes the MySQL
service, and then deletes the configuration file. The server
installation and its data folder are not removed.
If you choose the Re-configure Instance option, you advance
to the Configuration Type dialog where you can choose the
type of installation that you wish to configure.
2.3.6.3 Choosing a Configuration Type
When you start the MySQL Server Instance Configuration Wizard
for a new MySQL installation, or choose the Re-configure
Instance option for an existing installation, you advance to
the Configuration Type dialog.
MySQL Server Instance Configuration Wizard: Configuration
Type
There are two configuration types available: Detailed
Configuration and Standard Configuration. The Standard
Configuration option is intended for new users who want to
get started with MySQL quickly without having to make many
decisions about server configuration. The Detailed
Configuration option is intended for advanced users who want
more fine-grained control over server configuration.
If you are new to MySQL and need a server configured as a
single-user developer machine, the Standard Configuration
should suit your needs. Choosing the Standard Configuration
option causes the MySQL Configuration Wizard to set all
configuration options automatically with the exception of
Service Options and Security Options.
The Standard Configuration sets options that may be
incompatible with systems where there are existing MySQL
installations. If you have an existing MySQL installation on
your system in addition to the installation you wish to
configure, the Detailed Configuration option is recommended.
To complete the Standard Configuration, please refer to the
sections on Service Options and Security Options in Section
2.3.6.10, "The Service Options Dialog," and Section 2.3.6.11,
"The Security Options Dialog," respectively.
2.3.6.4 The Server Type Dialog
There are three different server types available to choose
from. The server type that you choose affects the decisions
that the MySQL Server Instance Configuration Wizard makes
with regard to memory, disk, and processor usage.
MySQL Server Instance Configuration Wizard: Server Type
* Developer Machine: Choose this option for a typical
desktop workstation where MySQL is intended only for
personal use. It is assumed that many other desktop
applications are running. The MySQL server is configured
to use minimal system resources.
* Server Machine: Choose this option for a server machine
where the MySQL server is running alongside other server
applications such as FTP, email, and Web servers. The
MySQL server is configured to use a moderate portion of
the system resources.
* Dedicated MySQL Server Machine: Choose this option for a
server machine that is intended to run only the MySQL
server. It is assumed that no other applications are
running. The MySQL server is configured to use all
available system resources.
Note
By selecting one of the preconfigured configurations, the
values and settings of various options in your my.cnf or
my.ini will be altered accordingly. The default values and
options as described in the reference manual may therefore be
different to the options and values that were created during
the execution of the configuration wizard.
2.3.6.5 The Database Usage Dialog
The Database Usage dialog enables you to indicate the storage
engines that you expect to use when creating MySQL tables.
The option you choose determines whether the InnoDB storage
engine is available and what percentage of the server
resources are available to InnoDB.
MySQL Server Instance Configuration Wizard: Usage Dialog
* Multifunctional Database: This option enables both the
InnoDB and MyISAM storage engines and divides resources
evenly between the two. This option is recommended for
users who use both storage engines on a regular basis.
* Transactional Database Only: This option enables both the
InnoDB and MyISAM storage engines, but dedicates most
server resources to the InnoDB storage engine. This
option is recommended for users who use InnoDB almost
exclusively and make only minimal use of MyISAM.
* Non-Transactional Database Only: This option disables the
InnoDB storage engine completely and dedicates all server
resources to the MyISAM storage engine. This option is
recommended for users who do not use InnoDB.
The Configuration Wizard uses a template to generate the
server configuration file. The Database Usage dialog sets one
of the following option strings:
Multifunctional Database: MIXED
Transactional Database Only: INNODB
Non-Transactional Database Only: MYISAM
When these options are processed through the default template
(my-template.ini) the result is:
Multifunctional Database:
default-storage-engine=InnoDB
_myisam_pct=50
Transactional Database Only:
default-storage-engine=InnoDB
_myisam_pct=5
Non-Transactional Database Only:
default-storage-engine=MyISAM
_myisam_pct=100
skip-innodb
The _myisam_pct value is used to calculate the percentage of
resources dedicated to MyISAM. The remaining resources are
allocated to InnoDB.
2.3.6.6 The InnoDB Tablespace Dialog
Some users may want to locate the InnoDB tablespace files in
a different location than the MySQL server data directory.
Placing the tablespace files in a separate location can be
desirable if your system has a higher capacity or higher
performance storage device available, such as a RAID storage
system.
MySQL Server Instance Configuration Wizard: InnoDB Data
Tablespace
To change the default location for the InnoDB tablespace
files, choose a new drive from the drop-down list of drive
letters and choose a new path from the drop-down list of
paths. To create a custom path, click the ... button.
If you are modifying the configuration of an existing server,
you must click the Modify button before you change the path.
In this situation you must move the existing tablespace files
to the new location manually before starting the server.
2.3.6.7 The Concurrent Connections Dialog
To prevent the server from running out of resources, it is
important to limit the number of concurrent connections to
the MySQL server that can be established. The Concurrent
Connections dialog enables you to choose the expected usage
of your server, and sets the limit for concurrent connections
accordingly. It is also possible to set the concurrent
connection limit manually.
MySQL Server Instance Configuration Wizard: Connections
* Decision Support (DSS)/OLAP: Choose this option if your
server does not require a large number of concurrent
connections. The maximum number of connections is set at
100, with an average of 20 concurrent connections
assumed.
* Online Transaction Processing (OLTP): Choose this option
if your server requires a large number of concurrent
connections. The maximum number of connections is set at
500.
* Manual Setting: Choose this option to set the maximum
number of concurrent connections to the server manually.
Choose the number of concurrent connections from the
drop-down box provided, or enter the maximum number of
connections into the drop-down box if the number you
desire is not listed.
2.3.6.8 The Networking and Strict Mode Options Dialog
Use the Networking Options dialog to enable or disable TCP/IP
networking and to configure the port number that is used to
connect to the MySQL server.
MySQL Server Instance Configuration Wizard: Network
Configuration
TCP/IP networking is enabled by default. To disable TCP/IP
networking, uncheck the box next to the Enable TCP/IP
Networking option.
Port 3306 is used by default. To change the port used to
access MySQL, choose a new port number from the drop-down box
or type a new port number directly into the drop-down box. If
the port number you choose is in use, you are prompted to
confirm your choice of port number.
Set the Server SQL Mode to either enable or disable strict
mode. Enabling strict mode (default) makes MySQL behave more
like other database management systems. If you run
applications that rely on MySQL's old "forgiving" behavior,
make sure to either adapt those applications or to disable
strict mode. For more information about strict mode, see
Section 5.1.7, "Server SQL Modes."
2.3.6.9 The Character Set Dialog
The MySQL server supports multiple character sets and it is
possible to set a default server character set that is
applied to all tables, columns, and databases unless
overridden. Use the Character Set dialog to change the
default character set of the MySQL server.
MySQL Server Instance Configuration Wizard: Character Set
* Standard Character Set: Choose this option if you want to
use latin1 as the default server character set. latin1 is
used for English and many Western European languages.
* Best Support For Multilingualism: Choose this option if
you want to use utf8 as the default server character set.
This is a Unicode character set that can store characters
from many different languages.
* Manual Selected Default Character Set / Collation: Choose
this option if you want to pick the server's default
character set manually. Choose the desired character set
from the provided drop-down list.
2.3.6.10 The Service Options Dialog
On Windows platforms, the MySQL server can be installed as a
Windows service. When installed this way, the MySQL server
can be started automatically during system startup, and even
restarted automatically by Windows in the event of a service
failure.
The MySQL Server Instance Configuration Wizard installs the
MySQL server as a service by default, using the service name
MySQL. If you do not wish to install the service, uncheck the
box next to the Install As Windows Service option. You can
change the service name by picking a new service name from
the drop-down box provided or by entering a new service name
into the drop-down box.
Note
Service names can include any legal character except forward
(/) or backward (\) slashes, and must be less than 256
characters long.
Warning
If you are installing multiple versions of MySQL onto the
same machine, you must choose a different service name for
each version that you install. If you do not choose a
different service for each installed version then the service
manager information will be inconsistent and this will cause
problems when you try to uninstall a previous version.
If you have already installed multiple versions using the
same service name, you must manually edit the contents of the
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services
parameters within the Windows registry to update the
association of the service name with the correct server
version.
Typically, when installing multiple versions you create a
service name based on the version information. For example,
you might install MySQL 5.x as mysql5, or specific versions
such as MySQL 5.5.0 as mysql50500.
To install the MySQL server as a service but not have it
started automatically at startup, uncheck the box next to the
Launch the MySQL Server Automatically option.
2.3.6.11 The Security Options Dialog
The content of the security options portion of the MySQL
Server Instance Configuration Wizard will depend on whether
this is a new installation, or modifying an existing
installation.
* Setting the root password for a new installation
It is strongly recommended that you set a root password
for your MySQL server, and the MySQL Server Instance
Config Wizard requires by default that you do so. If you
do not wish to set a root password, uncheck the box next
to the Modify Security Settings option.
MySQL Server Instance Config Wizard: Security
* To set the root password, enter the desired password into
both the New root password and Confirm boxes.
Setting the root password for an existing installation
If you are modifying the configuration of an existing
configuration, or you are installing an upgrade and the
MySQL Server Instance Configuration Wizard has detected
an existing MySQL system, then you must enter the
existing password for root before changing the
configuration information.
MySQL Server Instance Config Wizard: Security (Existing
Installation)
If you want to change the current root password, enter
the desired new password into both the New root password
and Confirm boxes.
To permit root logins from across the network, check the box
next to the Enable root access from remote machines option.
This decreases the security of your root account.
To create an anonymous user account, check the box next to
the Create An Anonymous Account option. Creating an anonymous
account can decrease server security and cause login and
permission difficulties. For this reason, it is not
recommended.
2.3.6.12 The Confirmation Dialog
The final dialog in the MySQL Server Instance Configuration
Wizard is the Confirmation Dialog. To start the configuration
process, click the Execute button. To return to a previous
dialog, click the Back button. To exit the MySQL Server
Instance Configuration Wizard without configuring the server,
click the Cancel button.
MySQL Server Instance Configuration Wizard: Confirmation
After you click the Execute button, the MySQL Server Instance
Configuration Wizard performs a series of tasks and displays
the progress onscreen as the tasks are performed.
The MySQL Server Instance Configuration Wizard first
determines configuration file options based on your choices
using a template prepared by MySQL developers and engineers.
This template is named my-template.ini and is located in your
server installation directory.
The MySQL Configuration Wizard then writes these options to
the corresponding configuration file.
If you chose to create a service for the MySQL server, the
MySQL Server Instance Configuration Wizard creates and starts
the service. If you are reconfiguring an existing service,
the MySQL Server Instance Configuration Wizard restarts the
service to apply your configuration changes.
If you chose to set a root password, the MySQL Configuration
Wizard connects to the server, sets your new root password,
and applies any other security settings you may have
selected.
After the MySQL Server Instance Configuration Wizard has
completed its tasks, it displays a summary. Click the Finish
button to exit the MySQL Server Configuration Wizard.
2.3.6.13 MySQL Server Instance Config Wizard: Creating an Instance
from the Command Line
In addition to using the GUI interface to the MySQL Server
Instance Config Wizard, you can also create instances
automatically from the command line.
To use the MySQL Server Instance Config Wizard on the command
line, you need to use the MySQLInstanceConfig.exe command
that is installed with MySQL in the bin directory within the
installation directory. MySQLInstanceConfig.exe takes a
number of command-line arguments the set the properties that
would normally be selected through the GUI interface, and
then creates a new configuration file (my.ini) by combining
these selections with a template configuration file to
produce the working configuration file.
The main command line options are provided in the table
below. Some of the options are required, while some options
are optional.
Table 2.5 MySQL Server Instance Config Wizard Command Line
Options
Option Description
Required Parameters
-nPRODUCTNAME The name of the instance when installed
-pPATH Path of the base directory for installation. This is
equivalent to the directory when using the basedir
configuration parameter
-vVERSION The version tag to use for this installation
Action to Perform
-i Install an instance
-r Remove an instance
-s Stop an existing instance
-q Perform the operation quietly
-lFILENAME Sae the installation progress in a logfile
Config File to Use
-tFILENAME Path to the template config file that will be used
to generate the installed configuration file
-cFILENAME Path to a config file to be generated
The -t and -c options work together to set the configuration
parameters for a new instance. The -t option specifies the
template configuration file to use as the basic
configuration, which are then merged with the configuration
parameters generated by the MySQL Server Instance Config
Wizard into the configuration file specified by the -c
option.
A sample template file, my-template.ini is provided in the
toplevel MySQL installation directory. The file contains
elements are replaced automatically by the MySQL Server
Instance Config Wizard during configuration.
If you specify a configuration file that already exists, the
existing configuration file will be saved in the file with
the original, with the date and time added. For example, the
mysql.ini will be copied to mysql 2009-10-27 1646.ini.bak.
The parameters that you can specify on the command line are
listed in the table below.
Table 2.6 MySQL Server Instance Config Wizard Parameters
Parameter Description
ServiceName=$ Specify the name of the service to be created
AddBinToPath={yes | no} Specifies whether to add the binary
directory of MySQL to the standard PATH environment variable
ServerType={DEVELOPMENT | SERVER | DEDICATED} Specify the
server type. For more information, see Section 2.3.6.4, "The
Server Type Dialog"
DatabaseType={MIXED | INNODB | MYISAM} Specify the default
database type. For more information, see Section 2.3.6.5,
"The Database Usage Dialog"
ConnectionUsage={DSS | OLTP} Specify the type of connection
support, this automates the setting for the number of
concurrent connections (see the ConnectionCount parameter).
For more information, see Section 2.3.6.7, "The Concurrent
Connections Dialog"
ConnectionCount=# Specify the number of concurrent
connections to support. For more information, see Section
2.3.6.4, "The Server Type Dialog"
SkipNetworking={yes | no} Specify whether network support
should be supported. Specifying yes disables network access
altogether
Port=# Specify the network port number to use for network
connections. For more information, see Section 2.3.6.8, "The
Networking and Strict Mode Options Dialog"
StrictMode={yes | no} Specify whether to use the strict SQL
mode. For more information, see Section 2.3.6.8, "The
Networking and Strict Mode Options Dialog"
Charset=$ Specify the default character set. For more
information, see Section 2.3.6.9, "The Character Set Dialog"
RootPassword=$ Specify the root password
RootCurrentPassword=$ Specify the current root password then
stopping or reconfiguring an existing service
Note
When specifying options on the command line, you can enclose
the entire command-line option and the value you are
specifying using double quotation marks. This enables you to
use spaces in the options. For example, "-cC:\mysql.ini".
The following command installs a MySQL Server 5.5 instance
from the directory C:\Program Files\MySQL\MySQL Server 5.5
using the service name MySQL55 and setting the root password
to 1234.
shell> MySQLInstanceConfig.exe -i -q "-lC:\mysql_install_log.txt" »
"-nMySQL Server 5.5" "-pC:\Program Files\MySQL\MySQL Server 5.5" -v
5.5.47 »
"-tmy-template.ini" "-cC:\mytest.ini" ServerType=DEVELOPMENT Databa
seType=MIXED »
ConnectionUsage=DSS Port=3311 ServiceName=MySQL55 RootPassword=1234
In the above example, a log file will be generated in
mysql_install_log.txt containing the information about the
instance creation process. The log file generated by the
above example is shown below:
Welcome to the MySQL Server Instance Configuration Wizard 1.0.16.0
Date: 2009-10-27 17:07:21
Installing service ...
Product Name: MySQL Server 5.5
Version: 5.5.47
Installation Path: C:\Program Files\MySQL\MySQL Server 5.5\
Creating configuration file C:\mytest.ini using template my-template.i
ni.
Options:
DEVELOPMENT
MIXED
DSS
STRICTMODE
Variables:
port: 3311
default-character-set: latin1
basedir: "C:/Program Files/MySQL/MySQL Server 5.5/"
datadir: "C:/Program Files/MySQL/MySQL Server 5.5/Data/"
Creating Windows service entry.
Service name: "MySQL55"
Parameters: "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld" --d
efaults-file="C:\mytest.ini" MySQL55.
Windows service MySQL55 installed.
When using the command line, the return values in the
following table indicate an error performing the specified
option.
Table 2.7 Return Value from MySQL Server Instance Config
Wizard
Value Description
2 Configuration template file cannot be found
3 The Windows service entry cannot be created
4 Could not connect to the Service Control Manager
5 The MySQL service cannot be started
6 The MySQL service cannot be stopped
7 The security settings cannot be applied
8 The configuration file cannot be written
9 The Windows service entry cannot be removed
You can perform an installation of MySQL automatically using
the MSI package. For more information, see Section 2.3.5.2,
"Automating MySQL Installation on Microsoft Windows Using the
MSI Package."
2.3.7 Installing MySQL on Microsoft Windows Using a noinstall Zip
Archive
Users who are installing from the noinstall package can use
the instructions in this section to manually install MySQL.
The process for installing MySQL from a Zip archive is as
follows:
1. Extract the archive to the desired install directory
2. Create an option file
3. Choose a MySQL server type
4. Start the MySQL server
5. Secure the default user accounts
This process is described in the sections that follow.
2.3.7.1 Extracting the Install Archive
To install MySQL manually, do the following:
1. If you are upgrading from a previous version please refer
to Section 2.3.10, "Upgrading MySQL on Windows," before
beginning the upgrade process.
2. Make sure that you are logged in as a user with
administrator privileges.
3. Choose an installation location. Traditionally, the MySQL
server is installed in C:\mysql. The MySQL Installation
Wizard installs MySQL under C:\Program Files\MySQL. If
you do not install MySQL at C:\mysql, you must specify
the path to the install directory during startup or in an
option file. See Section 2.3.7.2, "Creating an Option
File."
Note
The MySQL Installer installs MySQL under C:\Program
Files\MySQL.
4. Extract the install archive to the chosen installation
location using your preferred Zip archive tool. Some
tools may extract the archive to a folder within your
chosen installation location. If this occurs, you can
move the contents of the subfolder into the chosen
installation location.
2.3.7.2 Creating an Option File
If you need to specify startup options when you run the
server, you can indicate them on the command line or place
them in an option file. For options that are used every time
the server starts, you may find it most convenient to use an
option file to specify your MySQL configuration. This is
particularly true under the following circumstances:
* The installation or data directory locations are
different from the default locations (C:\Program
Files\MySQL\MySQL Server 5.5 and C:\Program
Files\MySQL\MySQL Server 5.5\data).
* You need to tune the server settings, such as memory,
cache, or InnoDB configuration information.
When the MySQL server starts on Windows, it looks for option
files in several locations, such as the Windows directory,
C:\, and the MySQL installation directory (for the full list
of locations, see Section 4.2.6, "Using Option Files"). The
Windows directory typically is named something like
C:\WINDOWS. You can determine its exact location from the
value of the WINDIR environment variable using the following
command:
C:\> echo %WINDIR%
MySQL looks for options in each location first in the my.ini
file, and then in the my.cnf file. However, to avoid
confusion, it is best if you use only one file. If your PC
uses a boot loader where C: is not the boot drive, your only
option is to use the my.ini file. Whichever option file you
use, it must be a plain text file.
Note
When using the MySQL Installer to install MySQL Server, it
will create the my.ini at the default location. And as of
MySQL Server 5.5.27, the user running MySQL Installer is
granted full permissions to this new my.ini.
In other words, be sure that the MySQL Server user has
permission to read the my.ini file.
You can also make use of the example option files included
with your MySQL distribution; see Section 5.1.2, "Server
Configuration Defaults."
An option file can be created and modified with any text
editor, such as Notepad. For example, if MySQL is installed
in E:\mysql and the data directory is in E:\mydata\data, you
can create an option file containing a [mysqld] section to
specify values for the basedir and datadir options:
[mysqld]
# set basedir to your installation path
basedir=E:/mysql
# set datadir to the location of your data directory
datadir=E:/mydata/data
Microsoft Windows path names are specified in option files
using (forward) slashes rather than backslashes. If you do
use backslashes, double them:
[mysqld]
# set basedir to your installation path
basedir=E:\\mysql
# set datadir to the location of your data directory
datadir=E:\\mydata\\data
The rules for use of backslash in option file values are
given in Section 4.2.6, "Using Option Files."
The data directory is located within the AppData directory
for the user running MySQL.
If you would like to use a data directory in a different
location, you should copy the entire contents of the data
directory to the new location. For example, if you want to
use E:\mydata as the data directory instead, you must do two
things:
1. Move the entire data directory and all of its contents
from the default location (for example C:\Program
Files\MySQL\MySQL Server 5.5\data) to E:\mydata.
2. Use a --datadir option to specify the new data directory
location each time you start the server.
2.3.7.3 Selecting a MySQL Server Type
The following table shows the available servers for Windows
in MySQL 5.5.
Binary Description
mysqld Optimized binary with named-pipe support
mysqld-debug Like mysqld, but compiled with full debugging
and automatic memory allocation checking
All of the preceding binaries are optimized for modern Intel
processors, but should work on any Intel i386-class or higher
processor.
Each of the servers in a distribution support the same set of
storage engines. The SHOW ENGINES statement displays which
engines a given server supports.
All Windows MySQL 5.5 servers have support for symbolic
linking of database directories.
MySQL supports TCP/IP on all Windows platforms. MySQL servers
on Windows also support named pipes, if you start the server
with the --enable-named-pipe option. It is necessary to use
this option explicitly because some users have experienced
problems with shutting down the MySQL server when named pipes
were used. The default is to use TCP/IP regardless of
platform because named pipes are slower than TCP/IP in many
Windows configurations.
2.3.7.4 Starting the Server for the First Time
This section gives a general overview of starting the MySQL
server. The following sections provide more specific
information for starting the MySQL server from the command
line or as a Windows service.
The information here applies primarily if you installed MySQL
using the Noinstall version, or if you wish to configure and
test MySQL manually rather than with the GUI tools.
Note
The MySQL server will automatically start after using the
MySQL Installer, and the MySQL Notifier GUI can be used to
start/stop/restart at any time.
The examples in these sections assume that MySQL is installed
under the default location of C:\Program Files\MySQL\MySQL
Server 5.5. Adjust the path names shown in the examples if
you have MySQL installed in a different location.
Clients have two options. They can use TCP/IP, or they can
use a named pipe if the server supports named-pipe
connections.
MySQL for Windows also supports shared-memory connections if
the server is started with the --shared-memory option.
Clients can connect through shared memory by using the
--protocol=MEMORY option.
For information about which server binary to run, see Section
2.3.7.3, "Selecting a MySQL Server Type."
Testing is best done from a command prompt in a console
window (or "DOS window"). In this way you can have the server
display status messages in the window where they are easy to
see. If something is wrong with your configuration, these
messages make it easier for you to identify and fix any
problems.
To start the server, enter this command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld" --console
For a server that includes InnoDB support, you should see the
messages similar to those following as it starts (the path
names and sizes may differ):
InnoDB: The first specified datafile c:\ibdata\ibdata1 did not exist:
InnoDB: a new database to be created!
InnoDB: Setting file c:\ibdata\ibdata1 size to 209715200
InnoDB: Database physically writes the file full: wait...
InnoDB: Log file c:\iblogs\ib_logfile0 did not exist: new to be create
d
InnoDB: Setting log file c:\iblogs\ib_logfile0 size to 31457280
InnoDB: Log file c:\iblogs\ib_logfile1 did not exist: new to be create
d
InnoDB: Setting log file c:\iblogs\ib_logfile1 size to 31457280
InnoDB: Log file c:\iblogs\ib_logfile2 did not exist: new to be create
d
InnoDB: Setting log file c:\iblogs\ib_logfile2 size to 31457280
InnoDB: Doublewrite buffer not found: creating new
InnoDB: Doublewrite buffer created
InnoDB: creating foreign key constraint system tables
InnoDB: foreign key constraint system tables created
011024 10:58:25 InnoDB: Started
When the server finishes its startup sequence, you should see
something like this, which indicates that the server is ready
to service client connections:
mysqld: ready for connections
Version: '5.5.47' socket: '' port: 3306
The server continues to write to the console any further
diagnostic output it produces. You can open a new console
window in which to run client programs.
If you omit the --console option, the server writes
diagnostic output to the error log in the data directory
(C:\Program Files\MySQL\MySQL Server 5.5\data by default).
The error log is the file with the .err extension, and may be
set using the --log-error option.
Note
The accounts that are listed in the MySQL grant tables
initially have no passwords. After starting the server, you
should set up passwords for them using the instructions in
Section 2.10.4, "Securing the Initial MySQL Accounts."
2.3.7.5 Starting MySQL from the Windows Command Line
The MySQL server can be started manually from the command
line. This can be done on any version of Windows.
Note
The MySQL Notifier GUI can also be used to start/stop/restart
the MySQL server.
To start the mysqld server from the command line, you should
start a console window (or "DOS window") and enter this
command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld"
The path to mysqld may vary depending on the install location
of MySQL on your system.
You can stop the MySQL server by executing this command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqladmin" -u root
shutdown
Note
If the MySQL root user account has a password, you need to
invoke mysqladmin with the -p option and supply the password
when prompted.
This command invokes the MySQL administrative utility
mysqladmin to connect to the server and tell it to shut down.
The command connects as the MySQL root user, which is the
default administrative account in the MySQL grant system.
Note
Users in the MySQL grant system are wholly independent from
any login users under Microsoft Windows.
If mysqld doesn't start, check the error log to see whether
the server wrote any messages there to indicate the cause of
the problem. By default, the error log is located in the
C:\Program Files\MySQL\MySQL Server 5.5\data directory. It is
the file with a suffix of .err, or may be specified by
passing in the --log-error option. Alternatively, you can try
to start the server with the --console option; in this case,
the server may display some useful information on the screen
that will help solve the problem.
The last option is to start mysqld with the --standalone and
--debug options. In this case, mysqld writes a log file
C:\mysqld.trace that should contain the reason why mysqld
doesn't start. See Section 24.5.3, "The DBUG Package."
Use mysqld --verbose --help to display all the options that
mysqld supports.
2.3.7.6 Customizing the PATH for MySQL Tools
To make it easier to invoke MySQL programs, you can add the
path name of the MySQL bin directory to your Windows system
PATH environment variable:
* On the Windows desktop, right-click the My Computer icon,
and select Properties.
* Next select the Advanced tab from the System Properties
menu that appears, and click the Environment Variables
button.
* Under System Variables, select Path, and then click the
Edit button. The Edit System Variable dialogue should
appear.
* Place your cursor at the end of the text appearing in the
space marked Variable Value. (Use the End key to ensure
that your cursor is positioned at the very end of the
text in this space.) Then enter the complete path name of
your MySQL bin directory (for example, C:\Program
Files\MySQL\MySQL Server 5.5\bin)
Note
There must be a semicolon separating this path from any
values present in this field.
Dismiss this dialogue, and each dialogue in turn, by
clicking OK until all of the dialogues that were opened
have been dismissed. You should now be able to invoke any
MySQL executable program by typing its name at the DOS
prompt from any directory on the system, without having
to supply the path. This includes the servers, the mysql
client, and all MySQL command-line utilities such as
mysqladmin and mysqldump.
You should not add the MySQL bin directory to your
Windows PATH if you are running multiple MySQL servers on
the same machine.
Warning
You must exercise great care when editing your system PATH by
hand; accidental deletion or modification of any portion of
the existing PATH value can leave you with a malfunctioning
or even unusable system.
2.3.7.7 Starting MySQL as a Windows Service
On Windows, the recommended way to run MySQL is to install it
as a Windows service, so that MySQL starts and stops
automatically when Windows starts and stops. A MySQL server
installed as a service can also be controlled from the
command line using NET commands, or with the graphical
Services utility. Generally, to install MySQL as a Windows
service you should be logged in using an account that has
administrator rights.
Note
The MySQL Notifier GUI can also be used to monitor the status
of the MySQL service.
The Services utility (the Windows Service Control Manager)
can be found in the Windows Control Panel (under
Administrative Tools on Windows 2000, XP, Vista, and Server
2003). To avoid conflicts, it is advisable to close the
Services utility while performing server installation or
removal operations from the command line.
Installing the service
Before installing MySQL as a Windows service, you should
first stop the current server if it is running by using the
following command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqladmin"
-u root shutdown
Note
If the MySQL root user account has a password, you need to
invoke mysqladmin with the -p option and supply the password
when prompted.
This command invokes the MySQL administrative utility
mysqladmin to connect to the server and tell it to shut down.
The command connects as the MySQL root user, which is the
default administrative account in the MySQL grant system.
Note
Users in the MySQL grant system are wholly independent from
any login users under Windows.
Install the server as a service using this command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld" --install
The service-installation command does not start the server.
Instructions for that are given later in this section.
To make it easier to invoke MySQL programs, you can add the
path name of the MySQL bin directory to your Windows system
PATH environment variable:
* On the Windows desktop, right-click the My Computer icon,
and select Properties.
* Next select the Advanced tab from the System Properties
menu that appears, and click the Environment Variables
button.
* Under System Variables, select Path, and then click the
Edit button. The Edit System Variable dialogue should
appear.
* Place your cursor at the end of the text appearing in the
space marked Variable Value. (Use the End key to ensure
that your cursor is positioned at the very end of the
text in this space.) Then enter the complete path name of
your MySQL bin directory (for example, C:\Program
Files\MySQL\MySQL Server 5.5\bin), and there should be a
semicolon separating this path from any values present in
this field. Dismiss this dialogue, and each dialogue in
turn, by clicking OK until all of the dialogues that were
opened have been dismissed. You should now be able to
invoke any MySQL executable program by typing its name at
the DOS prompt from any directory on the system, without
having to supply the path. This includes the servers, the
mysql client, and all MySQL command-line utilities such
as mysqladmin and mysqldump.
You should not add the MySQL bin directory to your
Windows PATH if you are running multiple MySQL servers on
the same machine.
Warning
You must exercise great care when editing your system PATH by
hand; accidental deletion or modification of any portion of
the existing PATH value can leave you with a malfunctioning
or even unusable system.
The following additional arguments can be used when
installing the service:
* You can specify a service name immediately following the
--install option. The default service name is MySQL.
* If a service name is given, it can be followed by a
single option. By convention, this should be
--defaults-file=file_name to specify the name of an
option file from which the server should read options
when it starts.
The use of a single option other than --defaults-file is
possible but discouraged. --defaults-file is more
flexible because it enables you to specify multiple
startup options for the server by placing them in the
named option file.
* You can also specify a --local-service option following
the service name. This causes the server to run using the
LocalService Windows account that has limited system
privileges. This account is available only for Windows XP
or newer. If both --defaults-file and --local-service are
given following the service name, they can be in any
order.
For a MySQL server that is installed as a Windows service,
the following rules determine the service name and option
files that the server uses:
* If the service-installation command specifies no service
name or the default service name (MySQL) following the
--install option, the server uses the a service name of
MySQL and reads options from the [mysqld] group in the
standard option files.
* If the service-installation command specifies a service
name other than MySQL following the --install option, the
server uses that service name. It reads options from the
[mysqld] group and the group that has the same name as
the service in the standard option files. This enables
you to use the [mysqld] group for options that should be
used by all MySQL services, and an option group with the
service name for use by the server installed with that
service name.
* If the service-installation command specifies a
--defaults-file option after the service name, the server
reads options the same way as described in the previous
item, except that it reads options only from the named
file and ignores the standard option files.
As a more complex example, consider the following command:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld"
--install MySQL --defaults-file=C:\my-opts.cnf
Here, the default service name (MySQL) is given after the
--install option. If no --defaults-file option had been
given, this command would have the effect of causing the
server to read the [mysqld] group from the standard option
files. However, because the --defaults-file option is
present, the server reads options from the [mysqld] option
group, and only from the named file.
Note
On Windows, if the server is started with the --defaults-file
and --install options, --install must be first. Otherwise,
mysqld.exe will attempt to start the MySQL server.
You can also specify options as Start parameters in the
Windows Services utility before you start the MySQL service.
Starting the service
Once a MySQL server has been installed as a service, Windows
starts the service automatically whenever Windows starts. The
service also can be started immediately from the Services
utility, or by using a NET START MySQL command. The NET
command is not case sensitive.
When run as a service, mysqld has no access to a console
window, so no messages can be seen there. If mysqld does not
start, check the error log to see whether the server wrote
any messages there to indicate the cause of the problem. The
error log is located in the MySQL data directory (for
example, C:\Program Files\MySQL\MySQL Server 5.5\data). It is
the file with a suffix of .err.
When a MySQL server has been installed as a service, and the
service is running, Windows stops the service automatically
when Windows shuts down. The server also can be stopped
manually by using the Services utility, the NET STOP MySQL
command, or the mysqladmin shutdown command.
You also have the choice of installing the server as a manual
service if you do not wish for the service to be started
automatically during the boot process. To do this, use the
--install-manual option rather than the --install option:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld" --install-ma
nual
Removing the service
To remove a server that is installed as a service, first stop
it if it is running by executing NET STOP MySQL. Then use the
--remove option to remove it:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqld" --remove
If mysqld is not running as a service, you can start it from
the command line. For instructions, see Section 2.3.7.5,
"Starting MySQL from the Windows Command Line."
If you encounter difficulties during installation. see
Section 2.3.8, "Troubleshooting a Microsoft Windows MySQL
Server Installation."
2.3.7.8 Testing The MySQL Installation
You can test whether the MySQL server is working by executing
any of the following commands:
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqlshow"
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqlshow" -u root m
ysql
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysqladmin" version
status proc
C:\> "C:\Program Files\MySQL\MySQL Server 5.5\bin\mysql" test
If mysqld is slow to respond to TCP/IP connections from
client programs, there is probably a problem with your DNS.
In this case, start mysqld with the --skip-name-resolve
option and use only localhost and IP addresses in the Host
column of the MySQL grant tables. (Be sure that an account
exists that specifies an IP address or you may not be able to
connect.)
You can force a MySQL client to use a named-pipe connection
rather than TCP/IP by specifying the --pipe or
--protocol=PIPE option, or by specifying . (period) as the
host name. Use the --socket option to specify the name of the
pipe if you do not want to use the default pipe name.
If you have set a password for the root account, deleted the
anonymous account, or created a new user account, then to
connect to the MySQL server you must use the appropriate -u
and -p options with the commands shown previously. See
Section 4.2.2, "Connecting to the MySQL Server."
For more information about mysqlshow, see Section 4.5.6,
"mysqlshow --- Display Database, Table, and Column
Information."
2.3.8 Troubleshooting a Microsoft Windows MySQL Server Installation
When installing and running MySQL for the first time, you may
encounter certain errors that prevent the MySQL server from
starting. This section helps you diagnose and correct some of
these errors.
Your first resource when troubleshooting server issues is the
error log. The MySQL server uses the error log to record
information relevant to the error that prevents the server
from starting. The error log is located in the data directory
specified in your my.ini file. The default data directory
location is C:\Program Files\MySQL\MySQL Server 5.5\data, or
C:\ProgramData\Mysql on Windows 7 and Windows Server 2008.
The C:\ProgramData directory is hidden by default. You need
to change your folder options to see the directory and
contents. For more information on the error log and
understanding the content, see Section 5.2.2, "The Error
Log."
For information regarding possible errors, also consult the
console messages displayed when the MySQL service is
starting. Use the NET START MySQL command from the command
line after installing mysqld as a service to see any error
messages regarding the starting of the MySQL server as a
service. See Section 2.3.7.7, "Starting MySQL as a Windows
Service."
The following examples show other common error messages you
might encounter when installing MySQL and starting the server
for the first time:
* If the MySQL server cannot find the mysql privileges
database or other critical files, it displays these
messages:
System error 1067 has occurred.
Fatal error: Can't open and lock privilege tables:
Table 'mysql.user' doesn't exist
These messages often occur when the MySQL base or data
directories are installed in different locations than the
default locations (C:\Program Files\MySQL\MySQL Server
5.5 and C:\Program Files\MySQL\MySQL Server 5.5\data,
respectively).
This situation can occur when MySQL is upgraded and
installed to a new location, but the configuration file
is not updated to reflect the new location. In addition,
old and new configuration files might conflict. Be sure
to delete or rename any old configuration files when
upgrading MySQL.
If you have installed MySQL to a directory other than
C:\Program Files\MySQL\MySQL Server 5.5, ensure that the
MySQL server is aware of this through the use of a
configuration (my.ini) file. Put the my.ini file in your
Windows directory, typically C:\WINDOWS. To determine its
exact location from the value of the WINDIR environment
variable, issue the following command from the command
prompt:
C:\> echo %WINDIR%
You can create or modify an option file with any text
editor, such as Notepad. For example, if MySQL is
installed in E:\mysql and the data directory is
D:\MySQLdata, you can create the option file and set up a
[mysqld] section to specify values for the basedir and
datadir options:
[mysqld]
# set basedir to your installation path
basedir=E:/mysql
# set datadir to the location of your data directory
datadir=D:/MySQLdata
Microsoft Windows path names are specified in option
files using (forward) slashes rather than backslashes. If
you do use backslashes, double them:
[mysqld]
# set basedir to your installation path
basedir=C:\\Program Files\\MySQL\\MySQL Server 5.5
# set datadir to the location of your data directory
datadir=D:\\MySQLdata
The rules for use of backslash in option file values are
given in Section 4.2.6, "Using Option Files."
If you change the datadir value in your MySQL
configuration file, you must move the contents of the
existing MySQL data directory before restarting the MySQL
server.
See Section 2.3.7.2, "Creating an Option File."
* If you reinstall or upgrade MySQL without first stopping
and removing the existing MySQL service and install MySQL
using the MySQL Installer, you might see this error:
Error: Cannot create Windows service for MySql. Error: 0
This occurs when the Configuration Wizard tries to
install the service and finds an existing service with
the same name.
One solution to this problem is to choose a service name
other than mysql when using the configuration wizard.
This enables the new service to be installed correctly,
but leaves the outdated service in place. Although this
is harmless, it is best to remove old services that are
no longer in use.
To permanently remove the old mysql service, execute the
following command as a user with administrative
privileges, on the command line:
C:\> sc delete mysql
[SC] DeleteService SUCCESS
If the sc utility is not available for your version of
Windows, download the delsrv utility from
http://www.microsoft.com/windows2000/techinfo/reskit/tool
s/existing/delsrv-o.asp and use the delsrv mysql syntax.
2.3.9 Windows Postinstallation Procedures
GUI tools exist that perform most of the tasks described in
this section, including:
* MySQL Installer: Used to install and upgrade MySQL
products.
* MySQL Workbench: Manages the MySQL server and edits SQL
statements.
* MySQL Notifier: Starts, stops, or restarts the MySQL
server, and monitors its status.
* MySQL for Excel
(http://dev.mysql.com/doc/mysql-for-excel/en/index.html):
Edits MySQL data with Microsoft Excel.
On Windows, you need not create the data directory and the
grant tables. MySQL Windows distributions include the grant
tables with a set of preinitialized accounts in the mysql
database under the data directory.
Regarding passwords, if you installed MySQL using the MySQL
Installer, you may have already assigned passwords to the
accounts. (See Section 2.3.3, "Installing MySQL on Microsoft
Windows Using MySQL Installer.") Otherwise, use the
password-assignment procedure given in Section 2.10.4,
"Securing the Initial MySQL Accounts."
Before assigning passwords, you might want to try running
some client programs to make sure that you can connect to the
server and that it is operating properly. Make sure that the
server is running (see Section 2.3.7.4, "Starting the Server
for the First Time"). You can also set up a MySQL service
that runs automatically when Windows starts (see Section
2.3.7.7, "Starting MySQL as a Windows Service").
These instructions assume that your current location is the
MySQL installation directory and that it has a bin
subdirectory containing the MySQL programs used here. If that
is not true, adjust the command path names accordingly.
If you installed MySQL using MySQL Installer (see Section
2.3.3, "Installing MySQL on Microsoft Windows Using MySQL
Installer"), the default installation directory is C:\Program
Files\MySQL\MySQL Server 5.5:
C:\> cd "C:\Program Files\MySQL\MySQL Server 5.5"
A common installation location for installation from a Zip
package is C:\mysql:
C:\> cd C:\mysql
Alternatively, add the bin directory to your PATH environment
variable setting. That enables your command interpreter to
find MySQL programs properly, so that you can run a program
by typing only its name, not its path name. See Section
2.3.7.6, "Customizing the PATH for MySQL Tools."
With the server running, issue the following commands to
verify that you can retrieve information from the server. The
output should be similar to that shown here.
Use mysqlshow to see what databases exist:
C:\> bin\mysqlshow
+--------------------+
| Databases |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
The list of installed databases may vary, but will always
include the minimum of mysql and information_schema.
The preceding command (and commands for other MySQL programs
such as mysql) may not work if the correct MySQL account does
not exist. For example, the program may fail with an error,
or you may not be able to view all databases. If you
installed MySQL using MySQL Installer, the root user will
have been created automatically with the password you
supplied. In this case, you should use the -u root and -p
options. (You must use those options if you have already
secured the initial MySQL accounts.) With -p, the client
program prompts for the root password. For example:
C:\> bin\mysqlshow -u root -p
Enter password: (enter root password here)
+--------------------+
| Databases |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
If you specify a database name, mysqlshow displays a list of
the tables within the database:
C:\> bin\mysqlshow mysql
Database: mysql
+---------------------------+
| Tables |
+---------------------------+
| columns_priv |
| db |
| event |
| func |
| general_log |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| ndb_binlog_index |
| plugin |
| proc |
| procs_priv |
| proxies_priv |
| servers |
| slow_log |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
Use the mysql program to select information from a table in
the mysql database:
C:\> bin\mysql -e "SELECT User, Host, plugin FROM mysql.user" mysql
+------+-----------+-----------------------+
| User | Host | plugin |
+------+-----------+-----------------------+
| root | localhost | mysql_native_password |
+------+-----------+-----------------------+
For more information about mysql and mysqlshow, see Section
4.5.1, "mysql --- The MySQL Command-Line Tool," and Section
4.5.6, "mysqlshow --- Display Database, Table, and Column
Information."
2.3.10 Upgrading MySQL on Windows
To upgrade MySQL on Windows, follow these steps:
1. Review Section 2.11.1, "Upgrading MySQL," for additional
information on upgrading MySQL that is not specific to
Windows.
2. Always back up your current MySQL installation before
performing an upgrade. See Section 7.2, "Database Backup
Methods."
3. Download the latest Windows distribution of MySQL from
http://dev.mysql.com/downloads/.
4. Before upgrading MySQL, stop the server. If the server is
installed as a service, stop the service with the
following command from the command prompt:
C:\> NET STOP MySQL
If you are not running the MySQL server as a service, use
mysqladmin to stop it. For example, before upgrading from
MySQL 5.1 to 5.5, use mysqladmin from MySQL 5.1 as
follows:
C:\> "C:\Program Files\MySQL\MySQL Server 5.1\bin\mysqladmin" -u root
shutdown
Note
If the MySQL root user account has a password, invoke
mysqladmin with the -p option and enter the password when
prompted.
5. Before upgrading to MySQL 5.5 from a version previous to
4.1.5, or from a version of MySQL installed from a Zip
archive to a version of MySQL installed with the MySQL
Installation Wizard, you must first manually remove the
previous installation and MySQL service (if the server is
installed as a service).
To remove the MySQL service, use the following command:
C:\> C:\mysql\bin\mysqld --remove
If you do not remove the existing service, the MySQL
Installation Wizard may fail to properly install the new
MySQL service.
6. If you are using the MySQL Installer, start it as
described in Section 2.3.3, "Installing MySQL on
Microsoft Windows Using MySQL Installer."
If you are using the MySQL Installation Wizard, start the
wizard as described in Section 2.3.5.1, "Using the MySQL
Installation Wizard."
7. If you are upgrading MySQL from a Zip archive, extract
the archive. You may either overwrite your existing MySQL
installation (usually located at C:\mysql), or install it
into a different directory, such as C:\mysql5.
Overwriting the existing installation is recommended.
However, for upgrades (as opposed to installing for the
first time), you must remove the data directory from your
existing MySQL installation to avoid replacing your
current data files. To do so, follow these steps:
a. Unzip the Zip archive in some location other than
your current MySQL installation
b. Remove the data directory
c. Rezip the Zip archive
d. Unzip the modified Zip archive on top of your
existing installation
Alternatively:
a. Unzip the Zip archive in some location other than
your current MySQL installation
b. Remove the data directory
c. Move the data directory from the current MySQL
installation to the location of the just-removed
data directory
d. Remove the current MySQL installation
e. Move the unzipped installation to the location of
the just-removed installation
8. If you were running MySQL as a Windows service and you
had to remove the service earlier in this procedure,
reinstall the service. (See Section 2.3.7.7, "Starting
MySQL as a Windows Service.")
9. Restart the server. For example, use NET START MySQL if
you run MySQL as a service, or invoke mysqld directly
otherwise.
10. As Administrator, run mysql_upgrade to check your tables,
attempt to repair them if necessary, and update your
grant tables if they have changed so that you can take
advantage of any new capabilities. See Section 4.4.7,
"mysql_upgrade --- Check and Upgrade MySQL Tables."
11. If you encounter errors, see Section 2.3.8,
"Troubleshooting a Microsoft Windows MySQL Server
Installation."
2.4 Installing MySQL on OS X
For a list of OS X versions that the MySQL server supports,
see
http://www.mysql.com/support/supportedplatforms/database.html
.
MySQL for OS X is available in a number of different forms:
* Native Package Installer, which uses the native OS X
installer (DMG) to walk you through the installation of
MySQL. For more information, see Section 2.4.2,
"Installing MySQL on OS X Using Native Packages." You can
use the package installer with OS X. The user you use to
perform the installation must have administrator
privileges.
* Compressed TAR archive, which uses a file packaged using
the Unix tar and gzip commands. To use this method, you
will need to open a Terminal window. You do not need
administrator privileges using this method, as you can
install the MySQL server anywhere using this method. For
more information on using this method, you can use the
generic instructions for using a tarball, Section 2.2,
"Installing MySQL on Unix/Linux Using Generic Binaries."
In addition to the core installation, the Package
Installer also includes Section 2.4.3, "Installing a
MySQL Launch Daemon" and Section 2.4.4, "Installing and
Using the MySQL Preference Pane," both of which simplify
the management of your installation.
For additional information on using MySQL on OS X, see
Section 2.4.1, "General Notes on Installing MySQL on OS X."
2.4.1 General Notes on Installing MySQL on OS X
You should keep the following issues and notes in mind:
* As of MySQL server 5.5.45, the DMG bundles a launchd
daemon instead of the deprecated startup item. Startup
items do not function as of OS X 10.10 (Yosemite), so
using launchd is preferred. The available MySQL
preference pane under OS X System Preferences was also
updated to use launchd.
* You may need (or want) to create a specific mysql user to
own the MySQL directory and data. You can do this through
the Directory Utility, and the mysql user should already
exist. For use in single user mode, an entry for _mysql
(note the underscore prefix) should already exist within
the system /etc/passwd file.
* Because the MySQL package installer installs the MySQL
contents into a version and platform specific directory,
you can use this to upgrade and migrate your database
between versions. You will need to either copy the data
directory from the old version to the new version, or
alternatively specify an alternative datadir value to set
location of the data directory. By default, the MySQL
directories are installed under /usr/local/.
* You might want to add aliases to your shell's resource
file to make it easier to access commonly used programs
such as mysql and mysqladmin from the command line. The
syntax for bash is:
alias mysql=/usr/local/mysql/bin/mysql
alias mysqladmin=/usr/local/mysql/bin/mysqladmin
For tcsh, use:
alias mysql /usr/local/mysql/bin/mysql
alias mysqladmin /usr/local/mysql/bin/mysqladmin
Even better, add /usr/local/mysql/bin to your PATH
environment variable. You can do this by modifying the
appropriate startup file for your shell. For more
information, see Section 4.2.1, "Invoking MySQL
Programs."
* After you have copied over the MySQL database files from
the previous installation and have successfully started
the new server, you should consider removing the old
installation files to save disk space. Additionally, you
should also remove older versions of the Package Receipt
directories located in
/Library/Receipts/mysql-VERSION.pkg.
* Prior to OS X 10.7, MySQL server was bundled with OS X
Server.
2.4.2 Installing MySQL on OS X Using Native Packages
The package is located inside a disk image (.dmg) file that
you first need to mount by double-clicking its icon in the
Finder. It should then mount the image and display its
contents.
Note
Before proceeding with the installation, be sure to stop all
running MySQL server instances by using either the MySQL
Manager Application (on OS X Server), the preference pane, or
mysqladmin shutdown on the command line.
When installing from the package version, you can also
install the MySQL preference pane, which will enable you to
control the startup and execution of your MySQL server from
System Preferences. For more information, see Section 2.4.4,
"Installing and Using the MySQL Preference Pane."
When installing using the package installer, the files are
installed into a directory within /usr/local matching the
name of the installation version and platform. For example,
the installer file mysql-5.5.47-osx10.9-x86_64.dmg installs
MySQL into /usr/local/mysql-5.5.47-osx10.9-x86_64/ . The
following table shows the layout of the installation
directory.
Table 2.8 MySQL Installation Layout on OS X
Directory Contents of Directory
bin, scripts mysqld server, client and utility programs
data Log files, databases
docs Helper documents, like the Release Notes and build
information
include Include (header) files
lib Libraries
man Unix manual pages
mysql-test MySQL test suite
share Miscellaneous support files, including error messages,
sample configuration files, SQL for database installation
sql-bench Benchmarks
support-files Scripts and sample configuration files
/tmp/mysql.sock Location of the MySQL Unix socket
During the package installer process, a symbolic link from
/usr/local/mysql to the version/platform specific directory
created during installation will be created automatically.
1. Download and open the MySQL package installer, which is
provided on a disk image (.dmg) that includes the main
MySQL installation package file. Double-click the disk
image to open it.
Figure 2.42 MySQL Package Installer: DMG Contents
MySQL Package Installer: DMG Contents
2. Double-click the MySQL installer package. It will be
named according to the version of MySQL you have
downloaded. For example, if you have downloaded MySQL
server 5.5.47, double-click
mysql-5.5.47-osx-10.9-x86_64.pkg.
3. You will be presented with the opening installer dialog.
Click Continue to begin installation.
Figure 2.43 MySQL Package Installer: Introduction
MySQL Package Installer: Introduction
4. If you have downloaded the community version of MySQL,
you will be shown a copy of the relevant GNU General
Public License. Click Continue and then Agree to
continue.
5. From the Installation Type page you can either click
Install to execute the installation wizard using all
defaults, click Customize to alter which components to
install (MySQL server, Preference Pane, Launchd Support
-- all enabled by default), or click Change Installation
Location to change the type of installation for either
all users, only the user executing the Installer, or
define a custom location.
Figure 2.44 MySQL Package Installer: Installation Type
MySQL Package Installer: Installation Type
Figure 2.45 MySQL Package Installer: Destination Select
(Change Installation Location)
MySQL Package Installer: Destination Select (Change
Installation Location)
Figure 2.46 MySQL Package Installer: Customize
MySQL Package Installer: Customize
6. Click Install to begin the installation process.
7. Once the installation has been completed successfully,
you will be shown an Install Succeeded message with a
short summary. Now, Close the wizard and begin using the
MySQL server.
Figure 2.47 MySQL Package Installer: Summary
MySQL Package Installer: Summary
MySQL server is now installed, but it is not loaded (started)
by default. Use either launchctl from the command dline, or
start MySQL by clicking "Start" using the MySQL preference
pane. For additional information, see Section 2.4.3,
"Installing a MySQL Launch Daemon," and Section 2.4.4,
"Installing and Using the MySQL Preference Pane."
2.4.3 Installing a MySQL Launch Daemon
OS X uses launch daemons to automatically start, stop, and
manage processes and applications such as MySQL.
Note
Before MySQL 5.5.45, the OS X builds installed startup items
instead of launchd daemons. However, startup items do not
function as of OS X 10.10 (Yosemite). The OS X builds now
install launchd daemons.
By default, the installation package (DMG) on OS X installs a
launchd file named
/Library/LaunchDaemons/com.oracle.oss.mysql.mysqld.plist that
contains a plist definition similar to:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN"
"http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key> <string>com.oracle.oss.mysql.mysqld</
string>
<key>ProcessType</key> <string>Interactive</string>
<key>Disabled</key> <false/>
<key>RunAtLoad</key> <true/>
<key>KeepAlive</key> <true/>
<key>SessionCreate</key> <true/>
<key>LaunchOnlyOnce</key> <false/>
<key>UserName</key> <string>_mysql</string>
<key>GroupName</key> <string>_mysql</string>
<key>ExitTimeOut</key> <integer>600</integer>
<key>Program</key> <string>/usr/local/mysql/bin/mysqld</
string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/mysql/bin/mysqld</string>
<string>--user=_mysql</string>
<string>--basedir=/usr/local/mysql</string>
<string>--datadir=/usr/local/mysql/data</string>
<string>--plugin-dir=/usr/local/mysql/lib/plugin</string>
<string>--log-error=/usr/local/mysql/data/mysqld.local.err
</string>
<string>--pid-file=/usr/local/mysql/data/mysqld.local.pid<
/string>
<string>--port=3306</string>
</array>
<key>WorkingDirectory</key> <string>/usr/local/mysql</string>
</dict>
</plist>
Note
Some users report that adding a plist DOCTYPE declaration
causes the launchd operation to fail, despite it passing the
lint check. We suspect it's a copy-n-paste error. The md5
checksum of a file containing the above snippet is
60d7963a0bb2994b69b8b9c123db09df.
To enable the launchd service, you can either:
* Click Start MySQL Server from the MySQL preference pane.
Figure 2.48 MySQL Preference Pane: Location
MySQL Preference Pane: Location
Figure 2.49 MySQL Preference Pane: Usage
MySQL Preference Pane: Usage
* Or, manually load the launchd file.
shell> cd /Library/LaunchDaemons
shell> sudo launchctl load -F com.oracle.oss.mysql.mysqld.plist
Note
When upgrading MySQL server, the launchd installation process
will remove the old startup items that were installed with
MySQL server 5.5.44 and below.
2.4.4 Installing and Using the MySQL Preference Pane
The MySQL Installation Package includes a MySQL preference
pane that enables you to start, stop, and control automated
startup during boot of your MySQL installation.
This preference pane is installed by default, and is listed
under your system's System Preferences window.
Figure 2.50 MySQL Preference Pane: Location
MySQL Preference Pane: Location
To install the MySQL Preference Pane:
1. Download and open the MySQL package installer, which is
provided on a disk image (.dmg) that includes the main
MySQL installation package.
Note
Before MySQL 5.5.45, OS X packages included the
deprecated startup items instead of launchd daemons, and
the preference pane managed that intstead of launchd.
Figure 2.51 MySQL Package Installer: DMG Contents
MySQL Package Installer: DMG Contents
2. Go through the process of installing the MySQL server, as
described in the documentation at Section 2.4.2,
"Installing MySQL on OS X Using Native Packages."
3. Click Customize at the Installation Type step. The
"Preference Pane" option is listed there and enabled by
default.
Figure 2.52 MySQL Installer on OS X: Customize
MySQL Installer on OS X: Customize
4. Complete the MySQL server installation process.
Note
The MySQL preference pane only starts and stops MySQL
installation installed from the MySQL package installation
that have been installed in the default location.
Once the MySQL preference pane has been installed, you can
control your MySQL server instance using the preference pane.
To use the preference pane, open the System Preferences...
from the Apple menu. Select the MySQL preference pane by
clicking the MySQL logo within the bottom section of the
preference panes list.
Figure 2.53 MySQL Preference Pane: Location
MySQL Preference Pane: Location
Figure 2.54 MySQL Preference Pane: Usage
MySQL Preference Pane: Usage
The MySQL Preference Pane shows the current status of the
MySQL server, showing stopped (in red) if the server is not
running and running (in green) if the server has already been
started. The preference pane also shows the current setting
for whether the MySQL server has been set to start
automatically.
* To start the MySQL server using the preference pane:
Click Start MySQL Server. You may be prompted for the
username and password of a user with administrator
privileges to start the MySQL server.
* To stop the MySQL server using the preference pane:
Click Stop MySQL Server. You may be prompted for the
username and password of a user with administrator
privileges to stop the MySQL server.
* To automatically start the MySQL server when the system
boots:
Check the check box next to Automatically Start MySQL
Server on Startup.
* To disable automatic MySQL server startup when the system
boots:
Uncheck the check box next to Automatically Start MySQL
Server on Startup.
You can close the System Preferences... window once you have
completed your settings.
2.5 Installing MySQL on Linux
Linux supports a number of different solutions for installing
MySQL. The recommended method is to use one of the
distributions from Oracle. If you choose this method, there
are several options available:
* Installing from a generic binary package in .tar.gz
format. See Section 2.2, "Installing MySQL on Unix/Linux
Using Generic Binaries" for more information.
* Extracting and compiling MySQL from a source
distribution. For detailed instructions, see Section 2.9,
"Installing MySQL from Source."
* Installing using a precompiled RPM package. For more
information, see Section 2.5.1, "Installing MySQL on
Linux Using RPM Packages."
* Installing using a precompiled Debian package. For more
information, see Section 2.5.2, "Installing MySQL on
Linux Using Debian Packages."
* Installing using Oracle's Unbreakable Linux Network
(ULN). For more information, see Section 2.6, "Installing
MySQL Using Unbreakable Linux Network (ULN)."
As an alternative, you can use the native package manager
within your Linux distribution to automatically download and
install MySQL for you. Native package installations can take
care of the download and dependencies required to run MySQL,
but the MySQL version will often be some versions behind the
currently available release. You will also normally be unable
to install development releases, as these are not usually
made available in the native repository. For more information
on using the native package installers, see Section 2.5.3,
"Installing MySQL on Linux Using Native Package Managers."
Note
For many Linux installations, you will want to set up MySQL
to be started automatically when your machine starts. Many of
the native package installations perform this operation for
you, but for source, binary and RPM solutions you may need to
set this up separately. The required script, mysql.server,
can be found in the support-files directory under the MySQL
installation directory or in a MySQL source tree. You can
install it as /etc/init.d/mysql for automatic MySQL startup
and shutdown. See Section 4.3.3, "mysql.server --- MySQL
Server Startup Script."
2.5.1 Installing MySQL on Linux Using RPM Packages
Note
To install or upgrade to MySQL 5.5.31, be sure to read the
special instructions at the end of this section.
The recommended way to install MySQL on RPM-based Linux
distributions is by using the RPM packages. The RPMs that we
provide to the community should work on all versions of Linux
that support RPM packages and use glibc 2.3. To obtain RPM
packages, see Section 2.1.2, "How to Get MySQL."
For non-RPM Linux distributions, you can install MySQL using
a .tar.gz package. See Section 2.2, "Installing MySQL on
Unix/Linux Using Generic Binaries."
Installations created from our Linux RPM distributions result
in files under the system directories shown in the following
table.
Table 2.9 MySQL Installation Layout for Linux RPM Packages
Directory Contents of Directory
/usr/bin Client programs and scripts
/usr/sbin The mysqld server
/var/lib/mysql Log files, databases
/usr/share/info MySQL manual in Info format
/usr/share/man Unix manual pages
/usr/include/mysql Include (header) files
/usr/lib/mysql Libraries
/usr/share/mysql Miscellaneous support files, including error
messages, character set files, sample configuration files,
SQL for database installation
/usr/share/sql-bench Benchmarks
Note
RPM distributions of MySQL are also provided by other
vendors. Be aware that they may differ from those built by
Oracle in features, capabilities, and conventions (including
communication setup), and that the instructions in this
manual do not necessarily apply to installing them. The
vendor's instructions should be consulted instead. Because of
these differences, RPM packages built by Oracle check whether
such RPMs built by other vendors are installed. If so, the
RPM does not install and produces a message explaining this.
Conflicts can arise when an RPM from another vendor is
already installed, such as when a vendor's conventions about
which files belong with the server and which belong with the
client library differ from the breakdown used for Oracle
packages. In such cases, attempts to install an Oracle RPM
with rpm -i may result in messages that files in the RPM to
be installed conflict with files from an installed package
(denoted mysql-libs in the following paragraphs).
Each MySQL release provides a MySQL-shared-compat package
that is meant to replace mysql-libs and provides a
replacement-compatible client library for older MySQL series.
MySQL-shared-compat is set up to make mysql-libs obsolete,
but rpm explicitly refuses to replace obsoleted packages when
invoked with -i (unlike -U), which is why installation with
rpm -i produces a conflict.
MySQL-shared-compat can safely be installed alongside
mysql-libs because libraries are installed to different
locations. Therefore, it is possible to install
MySQL-shared-compat first, then manually remove mysql-libs
before continuing with the installation. After mysql-libs is
removed, the dynamic linker stops looking for the client
library in the location where mysql-libs puts it, and the
library provided by the MySQL-shared-compat package takes
over.
Another alternative is to install packages using yum. In a
directory containing all RPM packages for a MySQL release,
yum install MySQL*rpm installs them in the correct order and
removes mysql-libs in one step without conflicts.
In most cases, you need install only the MySQL-server and
MySQL-client packages to get a functional standard MySQL
installation. The other packages are not required for a
standard installation.
RPMs for MySQL Cluster. Standard MySQL server RPMs built by
MySQL do not provide support for the NDBCLUSTER storage
engine.
Important
When upgrading a MySQL Cluster RPM installation, you must
upgrade all installed RPMs, including the Server and Client
RPMs.
For more information about installing MySQL Cluster from
RPMs, see Section 18.2, "MySQL Cluster Installation and
Upgrades."
For upgrades, if your installation was originally produced by
installing multiple RPM packages, it is best to upgrade all
the installed packages, not just some. For example, if you
previously installed the server and client RPMs, do not
upgrade just the server RPM.
If the data directory exists at RPM installation time, the
installation process does not modify existing data. This has
the effect, for example, that accounts in the grant tables
are not initialized to the default set of accounts.
If you get a dependency failure when trying to install MySQL
packages (for example, error: removing these packages would
break dependencies: libmysqlclient.so.10 is needed by ...),
you should also install the MySQL-shared-compat package,
which includes the shared libraries for older releases for
backward compatibility.
The following list shows the available RPM packages. The
names shown here use a suffix of .glibc23.i386.rpm, but
particular packages can have different suffixes, described
later. If you plan to install multiple RPM packages, you may
wish to download the RPM Bundle tar file instead, which
contains multiple RPM packages so that you need not download
them separately.
* MySQL-server-VERSION.glibc23.i386.rpm
The MySQL server. You need this unless you only want to
connect to a MySQL server running on another machine.
* MySQL-client-VERSION.glibc23.i386.rpm
The standard MySQL client programs. You probably always
want to install this package.
* MySQL-devel-VERSION.glibc23.i386.rpm
The libraries and include files needed to compile other
MySQL clients, such as the Perl MySQL module. Install
this RPM if you intend to compile C API applications.
* MySQL-shared-VERSION.glibc23.i386.rpm
This package contains the shared libraries
(libmysqlclient.so*) that certain languages and
applications need to dynamically load and use MySQL. It
contains single-threaded and thread-safe libraries.
Install this RPM if you intend to compile or run C API
applications that depend on the shared client library.
Prior to MySQL 5.5.6, if you install this package, do not
install the MySQL-shared-compat package.
* MySQL-shared-compat-VERSION.glibc23.i386.rpm
This package includes the shared libraries for older
releases. It contains single-threaded and thread-safe
libraries. Install this package if you have applications
installed that are dynamically linked against older
versions of MySQL but you want to upgrade to the current
version without breaking the library dependencies. Before
MySQL 5.5.6, MySQL-shared-compat also includes the
libraries for the current release, so if you install it,
you should not also install MySQL-shared. As of 5.5.6,
MySQL-shared-compat does not include the current library
version, so there is no conflict.
As of MySQL 5.5.23, the MySQL-shared-compat RPM package
enables users of Red Hat-provided mysql-*-5.1 RPM
packages to migrate to Oracle-provided MySQL-*-5.5
packages. MySQL-shared-compat replaces the Red Hat
mysql-libs package by replacing libmysqlclient.so files
of the latter package, thus satisfying dependencies of
other packages on mysql-libs. This change affects only
users of Red Hat (or Red Hat-compatible) RPM packages.
Nothing is different for users of Oracle RPM packages.
* MySQL-embedded-VERSION.glibc23.i386.rpm
The embedded MySQL server library.
* MySQL-test-VERSION.glibc23.i386.rpm
This package includes the MySQL test suite.
* MySQL-VERSION.src.rpm
This contains the source code for all of the previous
packages. It can also be used to rebuild the RPMs on
other architectures (for example, Alpha or SPARC).
In RPM package names, the suffix (following the VERSION
value) has the following syntax:
.PLATFORM.CPU.rpm
The PLATFORM and CPU values indicate the type of system for
which the package is built. PLATFORM indicates the platform
and CPU indicates the processor type or family.
All packages are dynamically linked against glibc 2.3. The
PLATFORM value indicates whether the package is platform
independent or intended for a specific platform, as shown in
the following table.
Table 2.10 MySQL Linux RPM Package Platforms
PLATFORM Value Intended Use
glibc23 Platform independent, should run on any Linux
distribution that supports glibc 2.3
rhel4, rhel5 Red Hat Enterprise Linux 4 or 5
el6 Enterprise Linux 6
sles10, sles11 SuSE Linux Enterprise Server 10 or 11
In MySQL 5.5, only glibc23 packages are available currently.
The CPU value indicates the processor type or family for
which the package is built, as shown in the following table.
Table 2.11 MySQL Linux RPM Package CPU Identifiers
CPU Value Intended Processor Type or Family
i386, i586, i686 Pentium processor or better, 32 bit
x86_64 64-bit x86 processor
ia64 Itanium (IA-64) processor
To see all files in an RPM package (for example, a
MySQL-server RPM), run a command like this (modify the
platform and CPU identifiers appropriately for your system):
shell> rpm -qpl MySQL-server-VERSION.glibc23.i386.rpm
To perform a standard minimal installation, install the
server and client RPMs:
shell> rpm -i MySQL-server-VERSION.glibc23.i386.rpm
shell> rpm -i MySQL-client-VERSION.glibc23.i386.rpm
To install only the client programs, install just the client
RPM:
shell> rpm -i MySQL-client-VERSION.glibc23.i386.rpm
RPM provides a feature to verify the integrity and
authenticity of packages before installing them. To learn
more about this feature, see Section 2.1.3, "Verifying
Package Integrity Using MD5 Checksums or GnuPG."
The server RPM places data under the /var/lib/mysql
directory. The RPM also creates a login account for a user
named mysql (if one does not exist) to use for running the
MySQL server, and creates the appropriate entries in
/etc/init.d/ to start the server automatically at boot time.
(This means that if you have performed a previous
installation and have made changes to its startup script, you
may want to make a copy of the script so that you can
reinstall it after you install a newer RPM.) See Section
2.10.5, "Starting and Stopping MySQL Automatically," for more
information on how MySQL can be started automatically on
system startup.
In MySQL 5.5.5 and later, during a new installation using RPM
packages, the server boot scripts are installed, but the
MySQL server is not started at the end of the installation,
since the status of the server during an unattended
installation is not known.
In MySQL 5.5.5 and later, during an upgrade installation
using RPM packages, if the MySQL server is running when the
upgrade occurs, the MySQL server is stopped, the upgrade
occurs, and the MySQL server is restarted. If the MySQL
server is not already running when the RPM upgrade occurs,
the MySQL server is not started at the end of the
installation.
If something goes wrong, you can find more information in the
binary installation section. See Section 2.2, "Installing
MySQL on Unix/Linux Using Generic Binaries."
Note
The accounts created in the MySQL grant tables for an RPM
installation initially have no passwords. After starting the
server, you should assign passwords to them using the
instructions in Section 2.10, "Postinstallation Setup and
Testing."
An RPM installation creates a user named mysql and a group
named mysql on the system using the useradd, groupadd, and
usermod commands. Those commands require appropriate
administrative privileges, which is required for locally
managed users and groups (as listed in the /etc/passwd and
/etc/group files) by the RPM installation process being run
by root.
If you log in as the mysql user, you may find that MySQL
displays "Invalid (old?) table or database name" errors that
mention .mysqlgui, lost+found, .mysqlgui, .bash_history,
.fonts.cache-1, .lesshst, .mysql_history, .profile, .viminfo,
and similar files created by MySQL or operating system
utilities. You can safely ignore these error messages or
remove the files or directories that cause them if you do not
need them.
For nonlocal user management (LDAP, NIS, and so forth), the
administrative tools may require additional authentication
(such as a password), and will fail if the installing user
does not provide this authentication. Even if they fail, the
RPM installation will not abort but succeed, and this is
intentional. If they failed, some of the intended transfer of
ownership may be missing, and it is recommended that the
system administrator then manually ensures some appropriate
user and group exists and manually transfers ownership
following the actions in the RPM spec file.
In MySQL 5.5.31, the RPM spec file has been updated, which
has the following consequences:
* For a non-upgrade installation (no existing MySQL version
installed), it possible to install MySQL using yum.
* For upgrades, it is necessary to clean up any earlier
MySQL installations. In effect, the update is performed
by removing the old installations and installing the new
one.
Additional details follow.
For a non-upgrade installation of MySQL 5.5.31, it is
possible to install using yum:
shell> yum install MySQL-server-NEWVERSION.glibc23.i386.rpm
For upgrades to MySQL 5.5.31, the upgrade is performed by
removing the old installation and installing the new one. To
do this, use the following procedure:
1. Remove the existing 5.5.X installation. OLDVERSION is the
version to remove.
shell> rpm -e MySQL-server-OLDVERSION.glibc23.i386.rpm
Repeat this step for all installed MySQL RPMs.
2. Install the new version. NEWVERSION is the version to
install.
shell> rpm -ivh MySQL-server-NEWVERSION.glibc23.i386.rpm
Alternatively, the removal and installation can be done using
yum:
shell> yum remove MySQL-server-OLDVERSION.glibc23.i386.rpm
shell> yum install MySQL-server-NEWVERSION.glibc23.i386.rpm
2.5.2 Installing MySQL on Linux Using Debian Packages
Oracle provides Debian packages for installation on Debian or
Debian-like Linux systems. To obtain a package, see Section
2.1.2, "How to Get MySQL."
Note
Debian distributions of MySQL are also provided by other
vendors. Be aware that they may differ from those built by us
in features, capabilities, and conventions (including
communication setup), and that the instructions in this
manual do not necessarily apply to installing them. The
vendor's instructions should be consulted instead.
Debian package files have names in mysql-MVER-DVER-CPU.deb
format. MVER is the MySQL version and DVER is the Debian
version. The CPU value indicates the processor type or family
for which the package is built, as shown in the following
table.
Table 2.12 MySQL Installation Packages for Linux CPU
Identifiers
CPU Value Intended Processor Type or Family
i686 Pentium processor or better, 32 bit
x86_64 64-bit x86 processor
After downloading a Debian package, use the following command
to install it;
shell> dpkg -i mysql-MVER-DVER-CPU.deb
The Debian package installs files in the
/opt/mysql/server-5.5 directory.
You may also need to install the libaio library if it is not
already present on your system:
shell> sudo apt-get install libaio1
2.5.3 Installing MySQL on Linux Using Native Package Managers
Many Linux distributions include a version of the MySQL
server, client tools, and development components into the
standard package management system built into distributions
such as Fedora, Debian, Ubuntu, and Gentoo. This section
provides basic instructions for installing MySQL using these
systems.
Important
Native package installations can take care of the download
and dependencies required to run MySQL, but the MySQL version
will often be some way behind the currently available
release. You will also normally be unable to install
development releases, as these are not usually made available
in the native repository.
Distribution specific instructions are shown below:
* Red Hat Linux, Fedora, CentOS
For Red Hat and similar distributions, the MySQL
distribution is divided into a number of separate
packages, mysql for the client tools, mysql-server for
the server and associated tools, and mysql-libs for the
libraries. The libraries are required if you want to
provide connectivity from different languages and
environments such as Perl, Python and others.
To install, use the yum command to specify the packages
that you want to install. For example:
root-shell> yum install mysql mysql-server mysql-libs mysql-server
Loaded plugins: presto, refresh-packagekit
Setting up Install Process
Resolving Dependencies
--> Running transaction check
---> Package mysql.x86_64 0:5.1.48-2.fc13 set to be updated
---> Package mysql-libs.x86_64 0:5.1.48-2.fc13 set to be updated
---> Package mysql-server.x86_64 0:5.1.48-2.fc13 set to be updated
--> Processing Dependency: perl-DBD-MySQL for package: mysql-server-5.
1.48-2.fc13.x86_64
--> Running transaction check
---> Package perl-DBD-MySQL.x86_64 0:4.017-1.fc13 set to be updated
--> Finished Dependency Resolution
Dependencies Resolved
======================================================================
==========
Package Arch Version Repository
Size
======================================================================
==========
Installing:
mysql x86_64 5.1.48-2.fc13 updates
889 k
mysql-libs x86_64 5.1.48-2.fc13 updates
1.2 M
mysql-server x86_64 5.1.48-2.fc13 updates
8.1 M
Installing for dependencies:
perl-DBD-MySQL x86_64 4.017-1.fc13 updates
136 k
Transaction Summary
======================================================================
==========
Install 4 Package(s)
Upgrade 0 Package(s)
Total download size: 10 M
Installed size: 30 M
Is this ok [y/N]: y
Downloading Packages:
Setting up and reading Presto delta metadata
Processing delta metadata
Package(s) data still to download: 10 M
(1/4): mysql-5.1.48-2.fc13.x86_64.rpm | 889 kB
00:04
(2/4): mysql-libs-5.1.48-2.fc13.x86_64.rpm | 1.2 MB
00:06
(3/4): mysql-server-5.1.48-2.fc13.x86_64.rpm | 8.1 MB
00:40
(4/4): perl-DBD-MySQL-4.017-1.fc13.x86_64.rpm | 136 kB
00:00
----------------------------------------------------------------------
----------
Total 201 kB/s | 10 MB
00:52
Running rpm_check_debug
Running Transaction Test
Transaction Test Succeeded
Running Transaction
Installing : mysql-libs-5.1.48-2.fc13.x86_64
1/4
Installing : mysql-5.1.48-2.fc13.x86_64
2/4
Installing : perl-DBD-MySQL-4.017-1.fc13.x86_64
3/4
Installing : mysql-server-5.1.48-2.fc13.x86_64
4/4
Installed:
mysql.x86_64 0:5.1.48-2.fc13 mysql-libs.x86_64 0:5.1.48-2
.fc13
mysql-server.x86_64 0:5.1.48-2.fc13
Dependency Installed:
perl-DBD-MySQL.x86_64 0:4.017-1.fc13
Complete!
MySQL and the MySQL server should now be installed. A
sample configuration file is installed into /etc/my.cnf.
An init script, to start and stop the server, will have
been installed into /etc/init.d/mysqld. To start the
MySQL server use service:
root-shell> service mysqld start
To enable the server to be started and stopped
automatically during boot, use chkconfig:
root-shell> chkconfig --levels 235 mysqld on
Which enables the MySQL server to be started (and
stopped) automatically at the specified the run levels.
The database tables will have been automatically created
for you, if they do not already exist. You should,
however, run mysql_secure_installation to set the root
passwords on your server.
* Debian, Ubuntu, Kubuntu
On Debian and related distributions, there are two
packages, mysql-client and mysql-server, for the client
and server components respectively. You should specify an
explicit version, for example mysql-client-5.1, to ensure
that you install the version of MySQL that you want.
To download and install, including any dependencies, use
the apt-get command, specifying the packages that you
want to install.
Note
Before installing, make sure that you update your apt-get
index files to ensure you are downloading the latest
available version.
A sample installation of the MySQL packages might look
like this (some sections trimmed for clarity):
root-shell> apt-get install mysql-client-5.1 mysql-server-5.1
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following packages were automatically installed and are no longer
required:
linux-headers-2.6.28-11 linux-headers-2.6.28-11-generic
Use 'apt-get autoremove' to remove them.
The following extra packages will be installed:
bsd-mailx libdbd-mysql-perl libdbi-perl libhtml-template-perl
libmysqlclient15off libmysqlclient16 libnet-daemon-perl libplrpc-per
l mailx
mysql-common postfix
Suggested packages:
dbishell libipc-sharedcache-perl tinyca procmail postfix-mysql postf
ix-pgsql
postfix-ldap postfix-pcre sasl2-bin resolvconf postfix-cdb
The following NEW packages will be installed
bsd-mailx libdbd-mysql-perl libdbi-perl libhtml-template-perl
libmysqlclient15off libmysqlclient16 libnet-daemon-perl libplrpc-per
l mailx
mysql-client-5.1 mysql-common mysql-server-5.1 postfix
0 upgraded, 13 newly installed, 0 to remove and 182 not upgraded.
Need to get 1907kB/25.3MB of archives.
After this operation, 59.5MB of additional disk space will be used.
Do you want to continue [Y/n]? Y
Get: 1 http://gb.archive.ubuntu.com jaunty-updates/main mysql-common 5
.1.30really5.0.75-0ubuntu10.5 [63.6kB]
Get: 2 http://gb.archive.ubuntu.com jaunty-updates/main libmysqlclient
15off 5.1.30really5.0.75-0ubuntu10.5 [1843kB]
Fetched 1907kB in 9s (205kB/s)
Preconfiguring packages ...
Selecting previously deselected package mysql-common.
(Reading database ... 121260 files and directories currently installed
.)
...
Processing 1 added doc-base file(s)...
Registering documents with scrollkeeper...
Setting up libnet-daemon-perl (0.43-1) ...
Setting up libplrpc-perl (0.2020-1) ...
Setting up libdbi-perl (1.607-1) ...
Setting up libmysqlclient15off (5.1.30really5.0.75-0ubuntu10.5) ...
Setting up libdbd-mysql-perl (4.008-1) ...
Setting up libmysqlclient16 (5.1.31-1ubuntu2) ...
Setting up mysql-client-5.1 (5.1.31-1ubuntu2) ...
Setting up mysql-server-5.1 (5.1.31-1ubuntu2) ...
* Stopping MySQL database server mysqld
...done.
100825 11:46:15 InnoDB: Started; log sequence number 0 46409
100825 11:46:15 InnoDB: Starting shutdown...
100825 11:46:17 InnoDB: Shutdown completed; log sequence number 0 464
09
100825 11:46:17 [Warning] Forcing shutdown of 1 plugins
* Starting MySQL database server mysqld
...done.
* Checking for corrupt, not cleanly closed and upgrade needing tables
.
...
Processing triggers for libc6 ...
ldconfig deferred processing now taking place
Note
The apt-get command will install a number of packages,
including the MySQL server, in order to provide the
typical tools and application environment. This can mean
that you install a large number of packages in addition
to the main MySQL package.
During installation, the initial database will be
created, and you will be prompted for the MySQL root
password (and confirmation). A configuration file will
have been created in /etc/mysql/my.cnf. An init script
will have been created in /etc/init.d/mysql.
The server will already be started. You can manually
start and stop the server using:
root-shell> service mysql [start|stop]
The service will automatically be added to the 2, 3 and 4
run levels, with stop scripts in the single, shutdown and
restart levels.
* Gentoo Linux
As a source-based distribution, installing MySQL on
Gentoo involves downloading the source, patching the
Gentoo specifics, and then compiling the MySQL server and
installing it. This process is handled automatically by
the emerge command. Depending on the version of MySQL
that you want to install, you may need to unmask the
specific version that you want for your chosen platform.
The MySQL server and client tools are provided within a
single package, dev-db/mysql. You can obtain a list of
the versions available to install by looking at the
portage directory for the package:
root-shell> ls /usr/portage/dev-db/mysql/mysql-5.1*
mysql-5.1.39-r1.ebuild
mysql-5.1.44-r1.ebuild
mysql-5.1.44-r2.ebuild
mysql-5.1.44-r3.ebuild
mysql-5.1.44.ebuild
mysql-5.1.45-r1.ebuild
mysql-5.1.45.ebuild
mysql-5.1.46.ebuild
To install a specific MySQL version, you must specify the
entire atom. For example:
root-shell> emerge =dev-db/mysql-5.1.46
A simpler alternative is to use the virtual/mysql-5.1
package, which will install the latest version:
root-shell> emerge =virtual/mysql-5.1
If the package is masked (because it is not tested or
certified for the current platform), use the
ACCEPT_KEYWORDS environment variable. For example:
root-shell> ACCEPT_KEYWORDS="~x86" emerge =virtual/mysql-5.1
After installation, you should create a new database
using mysql_install_db, and set the password for the root
user on MySQL. You can use the configuration interface to
set the password and create the initial database:
root-shell> emerge --config =dev-db/mysql-5.1.46
A sample configuration file will have been created for
you in /etc/mysql/my.cnf, and an init script will have
been created in /etc/init.d/mysql.
To enable MySQL to start automatically at the normal
(default) run levels, you can use:
root-shell> rc-update add mysql default
2.6 Installing MySQL Using Unbreakable Linux Network (ULN)
Linux supports a number of different solutions for installing
MySQL, covered in Section 2.5, "Installing MySQL on Linux."
One of the methods, covered in this section, is installing
from Oracle's Unbreakable Linux Network (ULN). You can find
information about Oracle Linux and ULN under
http://linux.oracle.com/.
To use ULN, you need to obtain a ULN login and register the
machine used for installation with ULN. This is described in
detail in the ULN FAQ
(https://linux.oracle.com/uln_faq.html). The page also
describes how to install and update packages.The MySQL
packages are in the "MySQL for Oracle Linux 6" channel for
your system architecture on ULN.
Note
At the time of this writing, ULN provides MySQL 5.5 for
Oracle Linux 6.
Once MySQL has been installed using ULN, you can find
information on starting and stopping the server, and more, in
this section, particularly under Section 2.5.1, "Installing
MySQL on Linux Using RPM Packages."
If you're updating an existing MySQL installation to an
installation using ULN, the recommended procedure is to
export your data using mysqldump, remove the existing
installation, install MySQL from ULN, and load the exported
data into your freshly installed MySQL.
If the existing MySQL installation you're upgrading from is
from a previous release series (prior to MySQL 5.5), make
sure to read the section on upgrading MySQL, Section 2.11.1,
"Upgrading MySQL."
2.7 Installing MySQL on Solaris and OpenSolaris
MySQL on Solaris and OpenSolaris is available in a number of
different formats.
* For information on installing using the native Solaris
PKG format, see Section 2.7.1, "Installing MySQL on
Solaris Using a Solaris PKG."
* On OpenSolaris, the standard package repositories include
MySQL packages specially built for OpenSolaris that
include entries for the Service Management Framework
(SMF) to enable control of the installation using the SMF
administration commands. For more information, see
Section 2.7.2, "Installing MySQL on OpenSolaris Using
IPS."
* To use a standard tar binary installation, use the notes
provided in Section 2.2, "Installing MySQL on Unix/Linux
Using Generic Binaries." Check the notes and hints at the
end of this section for Solaris specific notes that you
may need before or after installation.
To obtain a binary MySQL distribution for Solaris in tarball
or PKG format, http://dev.mysql.com/downloads/mysql/5.5.html.
Additional notes to be aware of when installing and using
MySQL on Solaris:
* If you want to use MySQL with the mysql user and group,
use the groupadd and useradd commands:
groupadd mysql
useradd -g mysql mysql
* If you install MySQL using a binary tarball distribution
on Solaris, you may run into trouble even before you get
the MySQL distribution unpacked, as the Solaris tar
cannot handle long file names. This means that you may
see errors when you try to unpack MySQL.
If this occurs, you must use GNU tar (gtar) to unpack the
distribution. In Solaris 10 and OpenSolaris gtar is
normally located in /usr/sfw/bin/gtar, but may not be
included in the default path definition.
* When using Solaris 10 for x86_64, you should mount any
file systems on which you intend to store InnoDB files
with the forcedirectio option. (By default mounting is
done without this option.) Failing to do so will cause a
significant drop in performance when using the InnoDB
storage engine on this platform.
* If you would like MySQL to start automatically, you can
copy support-files/mysql.server to /etc/init.d and create
a symbolic link to it named /etc/rc3.d/S99mysql.server.
* If too many processes try to connect very rapidly to
mysqld, you should see this error in the MySQL log:
Error in accept: Protocol error
You might try starting the server with the --back_log=50
option as a workaround for this.
* To configure the generation of core files on Solaris you
should use the coreadm command. Because of the security
implications of generating a core on a setuid()
application, by default, Solaris does not support core
files on setuid() programs. However, you can modify this
behavior using coreadm. If you enable setuid() core files
for the current user, they will be generated using the
mode 600 and owned by the superuser.
2.7.1 Installing MySQL on Solaris Using a Solaris PKG
You can install MySQL on Solaris and OpenSolaris using a
binary package using the native Solaris PKG format instead of
the binary tarball distribution.
To use this package, download the corresponding
mysql-VERSION-solaris10-PLATFORM.pkg.gz file, then uncompress
it. For example:
shell> gunzip mysql-5.5.47-solaris10-x86_64.pkg.gz
To install a new package, use pkgadd and follow the onscreen
prompts. You must have root privileges to perform this
operation:
shell> pkgadd -d mysql-5.5.47-solaris10-x86_64.pkg
The following packages are available:
1 mysql MySQL Community Server (GPL)
(i86pc) 5.5.47
Select package(s) you wish to process (or 'all' to process
all packages). (default: all) [?,??,q]:
The PKG installer installs all of the files and tools needed,
and then initializes your database if one does not exist. To
complete the installation, you should set the root password
for MySQL as provided in the instructions at the end of the
installation. Alternatively, you can run the
mysql_secure_installation script that comes with the
installation.
By default, the PKG package installs MySQL under the root
path /opt/mysql. You can change only the installation root
path when using pkgadd, which can be used to install MySQL in
a different Solaris zone. If you need to install in a
specific directory, use a binary tar file distribution.
The pkg installer copies a suitable startup script for MySQL
into /etc/init.d/mysql. To enable MySQL to startup and
shutdown automatically, you should create a link between this
file and the init script directories. For example, to ensure
safe startup and shutdown of MySQL you could use the
following commands to add the right links:
shell> ln /etc/init.d/mysql /etc/rc3.d/S91mysql
shell> ln /etc/init.d/mysql /etc/rc0.d/K02mysql
To remove MySQL, the installed package name is mysql. You can
use this in combination with the pkgrm command to remove the
installation.
To upgrade when using the Solaris package file format, you
must remove the existing installation before installing the
updated package. Removal of the package does not delete the
existing database information, only the server, binaries and
support files. The typical upgrade sequence is therefore:
shell> mysqladmin shutdown
shell> pkgrm mysql
shell> pkgadd -d mysql-5.5.47-solaris10-x86_64.pkg
shell> mysqld_safe &
shell> mysql_upgrade
You should check the notes in Section 2.11, "Upgrading or
Downgrading MySQL" before performing any upgrade.
2.7.2 Installing MySQL on OpenSolaris Using IPS
OpenSolaris includes standard packages for MySQL in the core
repository. The MySQL packages are based on a specific
release of MySQL and updated periodically. For the latest
release you must use either the native Solaris PKG, tar, or
source installations. The native OpenSolaris packages include
SMF files so that you can easily control your MySQL
installation, including automatic startup and recovery, using
the native service management tools.
To install MySQL on OpenSolaris, use the pkg command. You
will need to be logged in as root, or use the pfexec tool, as
shown in the example below:
shell> pfexec pkg install SUNWmysql55
The package set installs three individual packages,
SUNWmysql55lib, which contains the MySQL client libraries;
SUNWmysql55r which contains the root components, including
SMF and configuration files; and SUNWmysql55u which contains
the scripts, binary tools and other files. You can install
these packages individually if you only need the
corresponding components.
The MySQL files are installed into /usr/mysql which symbolic
links for the sub directories (bin, lib, etc.) to a version
specific directory. For MySQL 5.5, the full installation is
located in /usr/mysql/5.5. The default data directory is
/var/mysql/5.5/data. The configuration file is installed in
/etc/mysql/5.5/my.cnf. This layout permits multiple versions
of MySQL to be installed, without overwriting the data and
binaries from other versions.
Once installed, you must run mysql_install_db to initialize
the database, and use the mysql_secure_installation to secure
your installation.
Using SMF to manage your MySQL installation
Once installed, you can start and stop your MySQL server
using the installed SMF configuration. The service name is
mysql, or if you have multiple versions installed, you should
use the full version name, for example mysql:version_55. To
start and enable MySQL to be started at boot time:
shell> svcadm enable mysql
To disable MySQL from starting during boot time, and shut the
MySQL server down if it is running, use:
shell> svcadm disable mysql
To restart MySQL, for example after a configuration file
changes, use the restart option:
shell> svcadm restart mysql
You can also use SMF to configure the data directory and
enable full 64-bit mode. For example, to set the data
directory used by MySQL:
shell> svccfg
svc:> select mysql:version_55
svc:/application/database/mysql:version_55> setprop mysql/data=/data0/
mysql
By default, the 32-bit binaries are used. To enable the
64-bit server on 64-bit platforms, set the enable_64bit
parameter. For example:
svc:/application/database/mysql:version_55> setprop mysql/enable_64bit
=1
You need to refresh the SMF after settings these options:
shell> svcadm refresh mysql
2.8 Installing MySQL on FreeBSD
This section provides information about installing MySQL on
variants of FreeBSD Unix.
You can install MySQL on FreeBSD by using the binary
distribution provided by Oracle. For more information, see
Section 2.2, "Installing MySQL on Unix/Linux Using Generic
Binaries."
The easiest (and preferred) way to install MySQL is to use
the mysql-server and mysql-client ports available at
http://www.freebsd.org/. Using these ports gives you the
following benefits:
* A working MySQL with all optimizations enabled that are
known to work on your version of FreeBSD.
* Automatic configuration and build.
* Startup scripts installed in /usr/local/etc/rc.d.
* The ability to use pkg_info -L to see which files are
installed.
* The ability to use pkg_delete to remove MySQL if you no
longer want it on your machine.
The MySQL build process requires GNU make (gmake) to work. If
GNU make is not available, you must install it first before
compiling MySQL.
To install using the ports system:
# cd /usr/ports/databases/mysql51-server
# make
...
# cd /usr/ports/databases/mysql51-client
# make
...
The standard port installation places the server into
/usr/local/libexec/mysqld, with the startup script for the
MySQL server placed in /usr/local/etc/rc.d/mysql-server.
Some additional notes on the BSD implementation:
* To remove MySQL after installation using the ports
system:
# cd /usr/ports/databases/mysql51-server
# make deinstall
...
# cd /usr/ports/databases/mysql51-client
# make deinstall
...
* If you get problems with the current date in MySQL,
setting the TZ variable should help. See Section 2.12,
"Environment Variables."
2.9 Installing MySQL from Source
Building MySQL from the source code enables you to customize
build parameters, compiler optimizations, and installation
location. For a list of systems on which MySQL is known to
run, see
http://www.mysql.com/support/supportedplatforms/database.html
.
Before you proceed with an installation from source, check
whether Oracle produces a precompiled binary distribution for
your platform and whether it works for you. We put a great
deal of effort into ensuring that our binaries are built with
the best possible options for optimal performance.
Instructions for installing binary distributions are
available in Section 2.2, "Installing MySQL on Unix/Linux
Using Generic Binaries."
Note
This section describes how to build MySQL from source using
CMake. Before MySQL 5.5, source builds used the GNU autotools
on Unix-like systems. Source builds on Windows used CMake,
but the process was different from that described here. For
source-building instructions for older versions of MySQL, see
Installing MySQL from Source
(http://dev.mysql.com/doc/refman/5.1/en/source-installation.h
tml), in the MySQL 5.1 Reference Manual. If you are familiar
with autotools but not CMake, you might find these transition
instructions helpful: Autotools to CMake Transition Guide
(http://dev.mysql.com/doc/internals/en/autotools-to-cmake.htm
l)
Source Installation Methods
There are two methods for installing MySQL from source:
* Use a standard MySQL source distribution. To obtain a
standard distribution, see Section 2.1.2, "How to Get
MySQL." For instructions on building from a standard
distribution, see Section 2.9.2, "Installing MySQL Using
a Standard Source Distribution."
Standard distributions are available as compressed tar
files, Zip archives, or RPM packages. Distribution files
have names of the form mysql-VERSION.tar.gz,
mysql-VERSION.zip, or mysql-VERSION.rpm, where VERSION is
a number like 5.5.47. File names for source distributions
can be distinguished from those for precompiled binary
distributions in that source distribution names are
generic and include no platform name, whereas binary
distribution names include a platform name indicating the
type of system for which the distribution is intended
(for example, pc-linux-i686 or winx64).
* Use a MySQL development tree. For information on building
from one of the development trees, see Section 2.9.3,
"Installing MySQL Using a Development Source Tree."
Source Installation System Requirements
Installation of MySQL from source requires several
development tools. Some of these tools are needed no matter
whether you use a standard source distribution or a
development source tree. Other tool requirements depend on
which installation method you use.
To install MySQL from source, your system must have the
following tools, regardless of installation method:
* CMake, which is used as the build framework on all
platforms. CMake can be downloaded from
http://www.cmake.org.
* A good make program. Although some platforms come with
their own make implementations, it is highly recommended
that you use GNU make 3.75 or newer. It may already be
available on your system as gmake. GNU make is available
from http://www.gnu.org/software/make/.
* A working ANSI C++ compiler. GCC 4.2.1 or later, Sun
Studio 12 or later, Visual Studio 2008 or later, and many
current vendor-supplied compilers are known to work.
* Perl is needed if you intend to run test scripts. Most
Unix-like systems include Perl. On Windows, you can use a
version such as ActiveState Perl.
To install MySQL from a standard source distribution, one of
the following tools is required to unpack the distribution
file:
* For a .tar.gz compressed tar file: GNU gunzip to
uncompress the distribution and a reasonable tar to
unpack it. If your tar program supports the z option, it
can both uncompress and unpack the file.
GNU tar is known to work. The standard tar provided with
some operating systems is not able to unpack the long
file names in the MySQL distribution. You should download
and install GNU tar, or if available, use a preinstalled
version of GNU tar. Usually this is available as gnutar,
gtar, or as tar within a GNU or Free Software directory,
such as /usr/sfw/bin or /usr/local/bin. GNU tar is
available from http://www.gnu.org/software/tar/.
* For a .zip Zip archive: WinZip or another tool that can
read .zip files.
* For an .rpm RPM package: The rpmbuild program used to
build the distribution unpacks it.
To install MySQL from a development source tree, the
following additional tools are required:
* One of the following revision control systems is required
to obtain the development source code:
+ Git: The GitHub Help (https://help.github.com/)
provides instructions for downloading and installing
Git on different platforms. MySQL officially joined
GitHub in September, 2014. For more information
about MySQL's move to GitHub, refer to the
announcement on the MySQL Release Engineering blog:
MySQL on GitHub
(http://mysqlrelease.com/2014/09/mysql-on-github/)
+ Bazaar: The Bazaar VCS Web site
(http://bazaar-vcs.org) provides instructions for
downloading and installing Bazaar on different
platforms. Bazaar is supported on any platform that
supports Python, and is therefore compatible with
any Linux, Unix, Windows, or OS X host.
* bison 2.1 or newer, available from
http://www.gnu.org/software/bison/. (Version 1 is no
longer supported.) Use the latest version of bison where
possible; if you experience problems, upgrade to a later
version, rather than revert to an earlier one.
bison is available from
http://www.gnu.org/software/bison/. bison for Windows can
be downloaded from
http://gnuwin32.sourceforge.net/packages/bison.htm.
Download the package labeled "Complete package, excluding
sources". On Windows, the default location for bison is
the C:\Program Files\GnuWin32 directory. Some utilities
may fail to find bison because of the space in the
directory name. Also, Visual Studio may simply hang if
there are spaces in the path. You can resolve these
problems by installing into a directory that does not
contain a space; for example C:\GnuWin32.
* On OpenSolaris and Solaris Express, m4 must be installed
in addition to bison. m4 is available from
http://www.gnu.org/software/m4/.
Note
If you have to install any programs, modify your PATH
environment variable to include any directories in which the
programs are located. See Section 4.2.10, "Setting
Environment Variables."
If you run into problems and need to file a bug report,
please use the instructions in Section 1.6, "How to Report
Bugs or Problems."
2.9.1 MySQL Layout for Source Installation
By default, when you install MySQL after compiling it from
source, the installation step installs files under
/usr/local/mysql. The component locations under the
installation directory are the same as for binary
distributions. See Section 2.2, "MySQL Installation Layout
for Generic Unix/Linux Binary Package," and Section 2.3.1,
"MySQL Installation Layout on Microsoft Windows." To
configure installation locations different from the defaults,
use the options described at Section 2.9.4, "MySQL
Source-Configuration Options."
2.9.2 Installing MySQL Using a Standard Source Distribution
To install MySQL from a standard source distribution:
1. Verify that your system satisfies the tool requirements
listed at Section 2.9, "Installing MySQL from Source."
2. Obtain a distribution file using the instructions in
Section 2.1.2, "How to Get MySQL."
3. Configure, build, and install the distribution using the
instructions in this section.
4. Perform postinstallation procedures using the
instructions in Section 2.10, "Postinstallation Setup and
Testing."
In MySQL 5.5, CMake is used as the build framework on all
platforms. The instructions given here should enable you to
produce a working installation. For additional information on
using CMake to build MySQL, see How to Build MySQL Server
with CMake
(http://dev.mysql.com/doc/internals/en/cmake.html).
If you start from a source RPM, use the following command to
make a binary RPM that you can install. If you do not have
rpmbuild, use rpm instead.
shell> rpmbuild --rebuild --clean MySQL-VERSION.src.rpm
The result is one or more binary RPM packages that you
install as indicated in Section 2.5.1, "Installing MySQL on
Linux Using RPM Packages."
The sequence for installation from a compressed tar file or
Zip archive source distribution is similar to the process for
installing from a generic binary distribution (see Section
2.2, "Installing MySQL on Unix/Linux Using Generic
Binaries"), except that it is used on all platforms and
includes steps to configure and compile the distribution. For
example, with a compressed tar file source distribution on
Unix, the basic installation command sequence looks like
this:
# Preconfiguration setup
shell> groupadd mysql
shell> useradd -r -g mysql mysql
# Beginning of source-build specific instructions
shell> tar zxvf mysql-VERSION.tar.gz
shell> cd mysql-VERSION
shell> cmake .
shell> make
shell> make install
# End of source-build specific instructions
# Postinstallation setup
shell> cd /usr/local/mysql
shell> chown -R mysql .
shell> chgrp -R mysql .
shell> scripts/mysql_install_db --user=mysql
shell> chown -R root .
shell> chown -R mysql data
# Next command is optional
shell> cp support-files/my-medium.cnf /etc/my.cnf
shell> bin/mysqld_safe --user=mysql &
# Next command is optional
shell> cp support-files/mysql.server /etc/init.d/mysql.server
A more detailed version of the source-build specific
instructions is shown following.
Note
The procedure shown here does not set up any passwords for
MySQL accounts. After following the procedure, proceed to
Section 2.10, "Postinstallation Setup and Testing," for
postinstallation setup and testing.
Perform Preconfiguration Setup
On Unix, set up the mysql user and group that will be used to
run and execute the MySQL server and own the database
directory. For details, see Creating a mysql System User and
Group, in Section 2.2, "Installing MySQL on Unix/Linux Using
Generic Binaries." Then perform the following steps as the
mysql user, except as noted.
Obtain and Unpack the Distribution
Pick the directory under which you want to unpack the
distribution and change location into it.
Obtain a distribution file using the instructions in Section
2.1.2, "How to Get MySQL."
Unpack the distribution into the current directory:
* To unpack a compressed tar file, tar can uncompress and
unpack the distribution if it has z option support:
shell> tar zxvf mysql-VERSION.tar.gz
If your tar does not have z option support, use gunzip to
unpack the distribution and tar to unpack it:
shell> gunzip < mysql-VERSION.tar.gz | tar xvf -
Alternatively, CMake can uncompress and unpack the
distribution:
shell> cmake -E tar zxvf mysql-VERSION.tar.gz
* To unpack a Zip archive, use WinZip or another tool that
can read .zip files.
Unpacking the distribution file creates a directory named
mysql-VERSION.
Configure the Distribution
Change location into the top-level directory of the unpacked
distribution:
shell> cd mysql-VERSION
Configure the source directory. The minimum configuration
command includes no options to override configuration
defaults:
shell> cmake .
On Windows, specify the development environment. For example,
the following commands configure MySQL for 32-bit or 64-bit
builds, respectively:
shell> cmake . -G "Visual Studio 9 2008"
shell> cmake . -G "Visual Studio 9 2008 Win64"
On OS X, to use the Xcode IDE:
shell> cmake . -G Xcode
When you run cmake, you might want to add options to the
command line. Here are some examples:
* -DBUILD_CONFIG=mysql_release: Configure the source with
the same build options used by Oracle to produce binary
distributions for official MySQL releases.
* -DCMAKE_INSTALL_PREFIX=dir_name: Configure the
distribution for installation under a particular
location.
* -DCPACK_MONOLITHIC_INSTALL=1: Cause make package to
generate a single installation file rather than multiple
files.
* -DWITH_DEBUG=1: Build the distribution with debugging
support.
For a more extensive list of options, see Section 2.9.4,
"MySQL Source-Configuration Options."
To list the configuration options, use one of the following
commands:
shell> cmake . -L # overview
shell> cmake . -LH # overview with help text
shell> cmake . -LAH # all params with help text
shell> ccmake . # interactive display
If CMake fails, you might need to reconfigure by running it
again with different options. If you do reconfigure, take
note of the following:
* If CMake is run after it has previously been run, it may
use information that was gathered during its previous
invocation. This information is stored in CMakeCache.txt.
When CMake starts up, it looks for that file and reads
its contents if it exists, on the assumption that the
information is still correct. That assumption is invalid
when you reconfigure.
* Each time you run CMake, you must run make again to
recompile. However, you may want to remove old object
files from previous builds first because they were
compiled using different configuration options.
To prevent old object files or configuration information from
being used, run these commands on Unix before re-running
CMake:
shell> make clean
shell> rm CMakeCache.txt
Or, on Windows:
shell> devenv MySQL.sln /clean
shell> del CMakeCache.txt
If you build out of the source tree (as described later), the
CMakeCache.txt file and all built files are in the build
directory, so you can remove that directory to object files
and cached configuration information.
If you are going to send mail to a MySQL mailing list to ask
for configuration assistance, first check the files in the
CMakeFiles directory for useful information about the
failure. To file a bug report, please use the instructions in
Section 1.6, "How to Report Bugs or Problems."
Build the Distribution
On Unix:
shell> make
shell> make VERBOSE=1
The second command sets VERBOSE to show the commands for each
compiled source.
Use gmake instead on systems where you are using GNU make and
it has been installed as gmake.
On Windows:
shell> devenv MySQL.sln /build RelWithDebInfo
It is possible to build out of the source tree to keep the
tree clean. If the top-level source directory is named
mysql-src under your current working directory, you can build
in a directory named bld at the same level like this:
shell> mkdir bld
shell> cd bld
shell> cmake ../mysql-src
The build directory need not actually be outside the source
tree. For example, to build in a directory, you can build in
a directory named bld under the top-level source tree, do
this, starting with mysql-src as your current working
directory:
shell> mkdir bld
shell> cd bld
shell> cmake ..
If you have multiple source trees at the same level (for
example, to build multiple versions of MySQL), the second
strategy can be advantageous. The first strategy places all
build directories at the same level, which requires that you
choose a unique name for each. With the second strategy, you
can use the same name for the build directory within each
source tree.
If you have gotten to the compilation stage, but the
distribution does not build, see Section 2.9.5, "Dealing with
Problems Compiling MySQL," for help. If that does not solve
the problem, please enter it into our bugs database using the
instructions given in Section 1.6, "How to Report Bugs or
Problems." If you have installed the latest versions of the
required tools, and they crash trying to process our
configuration files, please report that also. However, if you
get a command not found error or a similar problem for
required tools, do not report it. Instead, make sure that all
the required tools are installed and that your PATH variable
is set correctly so that your shell can find them.
Install the Distribution
On Unix:
shell> make install
This installs the files under the configured installation
directory (by default, /usr/local/mysql). You might need to
run the command as root.
To install in a specific directory, add a DESTDIR parameter
to the command line:
shell> make install DESTDIR="/opt/mysql"
Alternatively, generate installation package files that you
can install where you like:
shell> make package
This operation produces one or more .tar.gz files that can be
installed like generic binary distribution packages. See
Section 2.2, "Installing MySQL on Unix/Linux Using Generic
Binaries." If you run CMake with
-DCPACK_MONOLITHIC_INSTALL=1, the operation produces a single
file. Otherwise, it produces multiple files.
On Windows, generate the data directory, then create a .zip
archive installation package:
shell> devenv MySQL.sln /build RelWithDebInfo /project initial_databas
e
shell> devenv MySQL.sln /build RelWithDebInfo /project package
You can install the resulting .zip archive where you like.
See Section 2.3.7, "Installing MySQL on Microsoft Windows
Using a noinstall Zip Archive."
Perform Postinstallation Setup
The remainder of the installation process involves setting up
the configuration file, creating the core databases, and
starting the MySQL server. For instructions, see Section
2.10, "Postinstallation Setup and Testing."
Note
The accounts that are listed in the MySQL grant tables
initially have no passwords. After starting the server, you
should set up passwords for them using the instructions in
Section 2.10, "Postinstallation Setup and Testing."
2.9.3 Installing MySQL Using a Development Source Tree
This section describes how to install MySQL from the latest
development source code, which is currently hosted on both
GitHub (https://github.com/) and Launchpad
(http://launchpad.net/). To obtain the MySQL Server source
code from one of these repository hosting services, you can
set up a local MySQL Git repository or a local MySQL Bazaar
branch.
* On GitHub (https://github.com/), MySQL Server and other
MySQL projects are found on the MySQL
(https://github.com/mysql) page. The MySQL Server project
is a single repository that contains branches for MySQL
5.5, 5.6, and 5.7.
MySQL officially joined GitHub in September, 2014. For
more information about MySQL's move to GitHub, refer to
the announcement on the MySQL Release Engineering blog:
MySQL on GitHub
(http://mysqlrelease.com/2014/09/mysql-on-github/)
* On Launchpad (http://launchpad.net/), MySQL projects,
including MySQL Server, MySQL Workbench, and others are
found on the Oracle/MySQL Engineering
(http://launchpad.net/~mysql) page. For the repositories
related only to MySQL Server, see the MySQL Server
(http://launchpad.net/mysql-server) page.
Note
The MySQL Server repositories on Launchpad are frozen as
of MySQL 5.5.41, MySQL 5.6.22, and MySQL 5.7.5. Updates
for later MySQL releases are published to GitHub
(https://github.com/mysql).
Prerequisites for Installing from Development Source
To install MySQL from a development source tree, your system
must satisfy the tool requirements outlined in Section 2.9,
"Installing MySQL from Source."
Setting Up a MySQL Git Repository
To set up a MySQL Git repository on your machine, use this
procedure:
1. Clone the MySQL Git repository to your machine. The
following command clones the MySQL Git repository to a
directory named mysql-server. The download size is
approximately 437 MB. The initial download will take some
time to complete, depending on the speed of your
connection.
~$ git clone https://github.com/mysql/mysql-server.git
Cloning into 'mysql-server'...
remote: Counting objects: 1035465, done.
remote: Total 1035465 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (1035465/1035465), 437.48 MiB | 5.10 MiB/s, do
ne.
Resolving deltas: 100% (855607/855607), done.
Checking connectivity... done.
Checking out files: 100% (21902/21902), done.
2. When the clone operation completes, the contents of your
local MySQL Git repository appear similar to the
following:
~$ cd mysql-server
~/mysql-server$ ls
BUILD COPYING libmysqld regex tests
BUILD-CMAKE dbug libservices scripts unitt
est
client Docs man sql VERSI
ON
cmake extra mysql-test sql-bench vio
CMakeLists.txt include mysys sql-common win
cmd-line-utils INSTALL-SOURCE packaging storage zlib
config.h.cmake INSTALL-WIN-SOURCE plugin strings
configure.cmake libmysql README support-files
3. Use the git branch -r command to view the remote tracking
branches for the MySQL repository.
~/mysql-server$ git branch -r
origin/5.5
origin/5.6
origin/5.7
origin/HEAD -> origin/5.7
origin/cluster-7.2
origin/cluster-7.3
origin/cluster-7.4
4. To view the branches that are checked out in your local
repository, issue the git branch command. When you cloned
the MySQL Git repository, the MySQL 5.7 branch was
checked out automatically. The asterisk identifies the
5.7 branch as the active branch.
~/mysql-server$ git branch
* 5.7
5. To check out a different MySQL branch, run the git
checkout command, specifying the branch name. For
example, to checkout the MySQL 5.5 branch:
~/mysql-server$ git checkout 5.5
Branch 5.5 set up to track remote branch 5.5 from origin.
Switched to a new branch '5.5'
6. Run git branch again to verify that the MySQL 5.5 branch
is present. MySQL 5.5, which is the last branch you
checked out, is marked by an asterisk indicating that it
is the active branch.
~/mysql-server$ git branch
* 5.5
5.7
The git checkout command is also used to switch branches.
For example, to make MySQL 5.7 the active branch again,
you would run git checkout 5.7.
7. To obtain changes made after your initial setup of the
MySQL Git repository, switch to the branch you want to
update and issue the git pull command:
~/mysql-server$ git checkout 5.5
~/mysql-server$ git pull
To examine the commit history, use the git log option:
~/mysql-server$ git log
You can also browse commit history and source code on the
GitHub MySQL (https://github.com/mysql) site.
If you see changes or code that you have a question
about, send an email to the MySQL internals mailing list.
See Section 1.5.1, "MySQL Mailing Lists." For information
about contributing a patch, see Contributing to MySQL
Server
(http://mysqlserverteam.com/contributing-to-mysql-server/
).
8. After you have cloned the MySQL Git repository and have
checked out the branch you want to build, you can build
MySQL Server from the source code. Instructions are
provided in Section 2.9.2, "Installing MySQL Using a
Standard Source Distribution," except that you skip the
part about obtaining and unpacking the distribution.
Be careful about installing a build from a distribution
source tree on a production machine. The installation
command may overwrite your live release installation. If
you already have MySQL installed and do not want to
overwrite it, run CMake with values for the
CMAKE_INSTALL_PREFIX, MYSQL_TCP_PORT, and MYSQL_UNIX_ADDR
options different from those used by your production
server. For additional information about preventing
multiple servers from interfering with each other, see
Section 5.3, "Running Multiple MySQL Instances on One
Machine."
Play hard with your new installation. For example, try to
make new features crash. Start by running make test. See
Section 24.1.2, "The MySQL Test Suite."
Setting Up a MySQL Bazaar Branch
Note
The MySQL Server repositories on Launchpad are frozen as of
MySQL 5.5.41, MySQL 5.6.22, and MySQL 5.7.5. Updates for
later MySQL releases are published to GitHub
(https://github.com/mysql).
To setup a MySQL Bazaar branch on your machine, use this
procedure:
1. To obtain a copy of the MySQL development source code
hosted on Launchpad (http://launchpad.net/), create a new
Bazaar branch. If you do not already have a Bazaar
repository directory set up, you must initialize a new
directory:
shell> mkdir mysql-server
shell> bzr init-repo --trees mysql-server
This is a one-time operation.
2. Assuming that you have an initialized repository
directory, you can branch from the public MySQL server
repositories to create a local source tree. To create a
branch of a specific version:
shell> cd mysql-server
shell> bzr branch lp:mysql-server/5.5 mysql-5.5
This is a one-time operation per source tree. You can
branch the source trees for several versions of MySQL
under the mysql-server directory.
The initial download will take some time to complete,
depending on the speed of your connection. Once you have
downloaded the first tree, additional trees should take
significantly less time to download.
3. When building from the Bazaar branch, you may want to
create a copy of your active branch so that you can make
configuration and other changes without affecting the
original branch contents. You can achieve this by
branching from the original branch:
shell> bzr branch mysql-5.5 mysql-5.5-build
4. To obtain changes made after you have set up the branch
initially, update it using the pull option periodically.
Use this command in the top-level directory of the local
copy:
shell> bzr pull
To examine the changeset comments for the tree, use the
log option to bzr:
shell> bzr log
You can also browse changesets, comments, and source code
online at the Launchpad MySQL Server
(http://launchpad.net/mysql-server) page.
If you see diffs (changes) or code that you have a
question about, do not hesitate to send email to the
MySQL internals mailing list. See Section 1.5.1, "MySQL
Mailing Lists." For information about contributing at
patch, see Contributing to MySQL Server
(http://mysqlserverteam.com/contributing-to-mysql-server/
).
5. After you have the local branch, you can build MySQL
server from the source code. Instructions are provided in
Section 2.9.2, "Installing MySQL Using a Standard Source
Distribution," except that you skip the part about
obtaining and unpacking the distribution.
Be careful about installing a build from a distribution
source tree on a production machine. The installation
command may overwrite your live release installation. If
you already have MySQL installed and do not want to
overwrite it, run CMake with values for the
CMAKE_INSTALL_PREFIX, MYSQL_TCP_PORT, and MYSQL_UNIX_ADDR
options different from those used by your production
server. For additional information about preventing
multiple servers from interfering with each other, see
Section 5.3, "Running Multiple MySQL Instances on One
Machine."
Play hard with your new installation. For example, try to
make new features crash. Start by running make test. See
Section 24.1.2, "The MySQL Test Suite."
2.9.4 MySQL Source-Configuration Options
The CMake program provides a great deal of control over how
you configure a MySQL source distribution. Typically, you do
this using options on the CMake command line. For information
about options supported by CMake, run either of these
commands in the top-level source directory:
shell> cmake . -LH
shell> ccmake .
You can also affect CMake using certain environment
variables. See Section 2.12, "Environment Variables."
The following table shows the available CMake options. In the
Default column, PREFIX stands for the value of the
CMAKE_INSTALL_PREFIX option, which specifies the installation
base directory. This value is used as the parent location for
several of the installation subdirectories.
Table 2.13 MySQL Source-Configuration Option Reference
(CMake)
Formats Description Default Introduced
BUILD_CONFIG Use same build options as official releases
5.5.7
CMAKE_BUILD_TYPE Type of build to produce RelWithDebInfo
5.5.7
CMAKE_C_FLAGS Flags for C Compiler
CMAKE_CXX_FLAGS Flags for C++ Compiler
CMAKE_INSTALL_PREFIX Installation base directory
/usr/local/mysql 5.5.8
COMPILATION_COMMENT Comment about compilation environment
5.5.7
CPACK_MONOLITHIC_INSTALL Whether package build produces
single file OFF 5.5.7
DEFAULT_CHARSET The default server character set latin1 5.5.7
DEFAULT_COLLATION The default server collation
latin1_swedish_ci 5.5.7
ENABLE_DEBUG_SYNC Whether to enable Debug Sync support ON
5.5.7
ENABLE_DOWNLOADS Whether to download optional files OFF 5.5.7
ENABLE_DTRACE Whether to include DTrace support 5.5.7
ENABLE_GCOV Whether to include gcov support 5.5.14
ENABLED_LOCAL_INFILE Whether to enable LOCAL for LOAD DATA
INFILE OFF 5.5.7
ENABLED_PROFILING Whether to enable query profiling code ON
5.5.7
IGNORE_AIO_CHECK With -DBUILD_CONFIG=mysql_release, ignore
libaio check OFF 5.5.9
INSTALL_BINDIR User executables directory PREFIX/bin 5.5.7
INSTALL_DOCDIR Documentation directory PREFIX/docs 5.5.7
INSTALL_DOCREADMEDIR README file directory PREFIX 5.5.7
INSTALL_INCLUDEDIR Header file directory PREFIX/include 5.5.7
INSTALL_INFODIR Info file directory PREFIX/docs 5.5.7
INSTALL_LAYOUT Select predefined installation layout
STANDALONE 5.5.7
INSTALL_LIBDIR Library file directory PREFIX/lib 5.5.7
INSTALL_MANDIR Manual page directory PREFIX/man 5.5.7
INSTALL_MYSQLSHAREDIR Shared data directory PREFIX/share
5.5.7
INSTALL_MYSQLTESTDIR mysql-test directory PREFIX/mysql-test
5.5.7
INSTALL_PLUGINDIR Plugin directory PREFIX/lib/plugin 5.5.7
INSTALL_SBINDIR Server executable directory PREFIX/bin 5.5.7
INSTALL_SCRIPTDIR Scripts directory PREFIX/scripts 5.5.7
INSTALL_SHAREDIR aclocal/mysql.m4 installation directory
PREFIX/share 5.5.7
INSTALL_SQLBENCHDIR sql-bench directory PREFIX 5.5.7
INSTALL_SUPPORTFILESDIR Extra support files directory
PREFIX/support-files 5.5.7
MEMCACHED_HOME Path to memcached [none] 5.5.16-ndb-7.2.2
MYSQL_DATADIR Data directory 5.5.7
MYSQL_MAINTAINER_MODE Whether to enable MySQL
maintainer-specific development environment OFF 5.5.7
MYSQL_PROJECT_NAME Windows/OS X project name 3306 5.5.21
MYSQL_TCP_PORT TCP/IP port number 3306 5.5.7
MYSQL_UNIX_ADDR Unix socket file /tmp/mysql.sock 5.5.7
ODBC_INCLUDES ODBC includes directory
ODBC_LIB_DIR ODBC library directory
SYSCONFDIR Option file directory 5.5.7
TMPDIR tmpdir default value 5.5.36
WITH_ASAN Enable AddressSanitizer OFF 5.5.35
WITH_BUNDLED_LIBEVENT Use bundled libevent when building
ndbmemcache ON 5.5.16-ndb-7.2.2
WITH_BUNDLED_MEMCACHED Use bundled memcached when building
ndbmemcache ON 5.5.16-ndb-7.2.2
WITH_CLASSPATH Classpath to use when building MySQL Cluster
Connector for Java. Default is an empty string.
WITH_DEBUG Whether to include debugging support OFF 5.5.7
WITH_EMBEDDED_SERVER Whether to build embedded server OFF
5.5.7
WITH_EMBEDDED_SHARED_LIBRARY Whether to build a shared
embedded server library OFF 5.5.37
WITH_xxx_STORAGE_ENGINE Compile storage engine xxx statically
into server 5.5.7
WITH_ERROR_INSERT Enable error injection in the NDB storage
engine. Should not be used for building binaries intended for
production. OFF
WITH_EXTRA_CHARSETS Which extra character sets to include all
5.5.7
WITH_LIBEDIT Use bundled libedit library ON 5.5.7
WITH_LIBWRAP Whether to include libwrap (TCP wrappers)
support OFF 5.5.7
WITH_NDB_BINLOG Enable binary logging by default by mysqld.
ON
WITH_NDB_DEBUG Produce a debug build for testing or
troubleshooting. OFF
WITH_NDB_JAVA Enable building of Java and ClusterJ support.
Enabled by default. Supported in MySQL Cluster only. ON
5.5.27-ndb-7.2.9
WITH_NDB_PORT Default port used by a management server built
with this option. If this option was not used to build it,
the management server's default port is 1186. [none]
WITH_NDB_TEST Include NDB API test programs. OFF
WITH_NDBCLUSTER Build the NDB storage engine; alias for
WITH_NDBCLUSTER_STORAGE_ENGINE ON
WITH_NDBCLUSTER_STORAGE_ENGINE Build the NDB storage engine
ON
WITH_NDBMTD Build multi-threaded data node. ON
WITH_READLINE Use bundled readline library OFF 5.5.7
WITH_SSL Type of SSL support bundled 5.5.7
WITH_UNIXODBC Enable unixODBC support OFF
WITH_VALGRIND Whether to compile in Valgrind header files OFF
5.5.6
WITH_ZLIB Type of zlib support system 5.5.7
WITHOUT_xxx_STORAGE_ENGINE Exclude storage engine xxx from
build 5.5.7
WITHOUT_SERVER Do not build the server OFF
The following sections provide more information about CMake
options.
* Section 2.9.4, ""
* Section 2.9.4, ""
* Section 2.9.4, ""
* Section 2.9.4, ""
* Section 2.9.4, ""
For boolean options, the value may be specified as 1 or ON to
enable the option, or as 0 or OFF to disable the option.
Many options configure compile-time defaults that can be
overridden at server startup. For example, the
CMAKE_INSTALL_PREFIX, MYSQL_TCP_PORT, and MYSQL_UNIX_ADDR
options that configure the default installation base
directory location, TCP/IP port number, and Unix socket file
can be changed at server startup with the --basedir, --port,
and --socket options for mysqld. Where applicable,
configuration option descriptions indicate the corresponding
mysqld startup option.
General Options
* -DBUILD_CONFIG=mysql_release
This option configures a source distribution with the
same build options used by Oracle to produce binary
distributions for official MySQL releases.
* -DCMAKE_BUILD_TYPE=type
The type of build to produce:
+ RelWithDebInfo: Enable optimizations and generate
debugging information. This is the default MySQL
build type.
+ Debug: Disable optimizations and generate debugging
information. This build type is also used if the
WITH_DEBUG option is enabled. That is,
-DWITH_DEBUG=1 has the same effect as
-DCMAKE_BUILD_TYPE=Debug.
* -DCPACK_MONOLITHIC_INSTALL=bool
This option affects whether the make package operation
produces multiple installation package files or a single
file. If disabled, the operation produces multiple
installation package files, which may be useful if you
want to install only a subset of a full MySQL
installation. If enabled, it produces a single file for
installing everything.
Installation Layout Options
The CMAKE_INSTALL_PREFIX option indicates the base
installation directory. Other options with names of the form
INSTALL_xxx that indicate component locations are interpreted
relative to the prefix and their values are relative
pathnames. Their values should not include the prefix.
* -DCMAKE_INSTALL_PREFIX=dir_name
The installation base directory.
This value can be set at server startup with the
--basedir option.
* -DINSTALL_BINDIR=dir_name
Where to install user programs.
* -DINSTALL_DOCDIR=dir_name
Where to install documentation.
* -DINSTALL_DOCREADMEDIR=dir_name
Where to install README files.
* -DINSTALL_INCLUDEDIR=dir_name
Where to install header files.
* -DINSTALL_INFODIR=dir_name
Where to install Info files.
* -DINSTALL_LAYOUT=name
Select a predefined installation layout:
+ STANDALONE: Same layout as used for .tar.gz and .zip
packages. This is the default.
+ RPM: Layout similar to RPM packages.
+ SVR4: Solaris package layout.
+ DEB: DEB package layout (experimental).
You can select a predefined layout but modify individual
component installation locations by specifying other
options. For example:
shell> cmake . -DINSTALL_LAYOUT=SVR4 -DMYSQL_DATADIR=/var/mysql/data
* -DINSTALL_LIBDIR=dir_name
Where to install library files.
* -DINSTALL_MANDIR=dir_name
Where to install manual pages.
* -DINSTALL_MYSQLSHAREDIR=dir_name
Where to install shared data files.
* -DINSTALL_MYSQLTESTDIR=dir_name
Where to install the mysql-test directory. As of MySQL
5.5.32, to suppress installation of this directory,
explicitly set the option to the empty value
(-DINSTALL_MYSQLTESTDIR=).
* -DINSTALL_PLUGINDIR=dir_name
The location of the plugin directory.
This value can be set at server startup with the
--plugin_dir option.
* -DINSTALL_SBINDIR=dir_name
Where to install the mysqld server.
* -DINSTALL_SCRIPTDIR=dir_name
Where to install mysql_install_db.
* -DINSTALL_SHAREDIR=dir_name
Where to install aclocal/mysql.m4.
* -DINSTALL_SQLBENCHDIR=dir_name
Where to install the sql-bench directory. To suppress
installation of this directory, explicitly set the option
to the empty value (-DINSTALL_SQLBENCHDIR=).
* -DINSTALL_SUPPORTFILESDIR=dir_name
Where to install extra support files.
* -DMYSQL_DATADIR=dir_name
The location of the MySQL data directory.
This value can be set at server startup with the
--datadir option.
* -DODBC_INCLUDES=dir_name
The location of the ODBC includes directory, and may be
used while configuring Connector/ODBC.
* -DODBC_LIB_DIR=dir_name
The location of the ODBC library directory, and may be
used while configuring Connector/ODBC.
* -DSYSCONFDIR=dir_name
The default my.cnf option file directory.
This location cannot be set at server startup, but you
can start the server with a given option file using the
--defaults-file=file_name option, where file_name is the
full path name to the file.
* -DTMPDIR=dir_name
The default location to use for the tmpdir system
variable. If unspecified, the value defaults to P_tmpdir
in <stdio.h>. This option was added in MySQL 5.6.16.
Storage Engine Options
Storage engines are built as plugins. You can build a plugin
as a static module (compiled into the server) or a dynamic
module (built as a dynamic library that must be installed
into the server using the INSTALL PLUGIN statement or the
--plugin-load option before it can be used). Some plugins
might not support static or dynamic building.
The MyISAM, MERGE, MEMORY, and CSV engines are mandatory
(always compiled into the server) and need not be installed
explicitly.
To compile a storage engine statically into the server, use
-DWITH_engine_STORAGE_ENGINE=1. Some permissible engine
values are ARCHIVE, BLACKHOLE, EXAMPLE, FEDERATED, INNOBASE
(InnoDB), NDBCLUSTER (NDB), PARTITION (partitioning support),
and PERFSCHEMA (Performance Schema). Examples:
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1
Note
WITH_NDBCLUSTER_STORAGE_ENGINE is supported only when
building MySQL Cluster using the MySQL Cluster sources. It
cannot be used to enable clustering support in other MySQL
source trees or distributions. In MySQL Cluster NDB 7.2
source distributions, it is enabled by default. See Section
18.2.1.3, "Building MySQL Cluster from Source on Linux," and
Section 18.2.2.2, "Compiling and Installing MySQL Cluster
from Source on Windows," for more information.
To exclude a storage engine from the build, use
-DWITHOUT_engine_STORAGE_ENGINE=1. Examples:
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
-DWITHOUT_PARTITION_STORAGE_ENGINE=1
If neither -DWITH_engine_STORAGE_ENGINE nor
-DWITHOUT_engine_STORAGE_ENGINE are specified for a given
storage engine, the engine is built as a shared module, or
excluded if it cannot be built as a shared module.
Feature Options
* -DCOMPILATION_COMMENT=string
A descriptive comment about the compilation environment.
* -DDEFAULT_CHARSET=charset_name
The server character set. By default, MySQL uses the
latin1 (cp1252 West European) character set.
charset_name may be one of binary, armscii8, ascii, big5,
cp1250, cp1251, cp1256, cp1257, cp850, cp852, cp866,
cp932, dec8, eucjpms, euckr, gb2312, gbk, geostd8, greek,
hebrew, hp8, keybcs2, koi8r, koi8u, latin1, latin2,
latin5, latin7, macce, macroman, sjis, swe7, tis620,
ucs2, ujis, utf8, utf8mb4, utf16, utf32. The permissible
character sets are listed in the
cmake/character_sets.cmake file as the value of
CHARSETS_AVAILABLE.
This value can be set at server startup with the
--character_set_server option.
* -DDEFAULT_COLLATION=collation_name
The server collation. By default, MySQL uses
latin1_swedish_ci. Use the SHOW COLLATION statement to
determine which collations are available for each
character set.
This value can be set at server startup with the
--collation_server option.
* -DENABLE_DEBUG_SYNC=bool
Whether to compile the Debug Sync facility into the
server. This facility is used for testing and debugging.
This option is enabled by default, but has no effect
unless MySQL is configured with debugging enabled. If
debugging is enabled and you want to disable Debug Sync,
use -DENABLE_DEBUG_SYNC=0.
When compiled in, Debug Sync is disabled by default at
runtime. To enable it, start mysqld with the
--debug-sync-timeout=N option, where N is a timeout value
greater than 0. (The default value is 0, which disables
Debug Sync.) N becomes the default timeout for individual
synchronization points.
For a description of the Debug Sync facility and how to
use synchronization points, see MySQL Internals: Test
Synchronization
(http://dev.mysql.com/doc/internals/en/test-synchronizati
on.html).
* -DENABLE_DOWNLOADS=bool
Whether to download optional files. For example, with
this option enabled, CMake downloads the Google Test
distribution that is used by the test suite to run unit
tests.
* -DENABLE_DTRACE=bool
Whether to include support for DTrace probes. For
information about DTrace, wee Section 5.4, "Tracing
mysqld Using DTrace"
* -DENABLE_GCOV=bool
Whether to include gcov support (Linux only).
* -DENABLED_LOCAL_INFILE=bool
Whether to enable LOCAL capability in the client library
for LOAD DATA INFILE.
This option controls client-side LOCAL capability, but
the capability can be set on the server side at server
startup with the --local-infile option. See Section
6.1.6, "Security Issues with LOAD DATA LOCAL."
* -DENABLED_PROFILING=bool
Whether to enable query profiling code (for the SHOW
PROFILE and SHOW PROFILES statements).
* -DIGNORE_AIO_CHECK=bool
If the -DBUILD_CONFIG=mysql_release option is given on
Linux, the libaio library must be linked in by default.
If you do not have libaio or do not want to install it,
you can suppress the check for it by specifying
-DIGNORE_AIO_CHECK=1. This option was added in MySQL
5.5.9.
* -DMYSQL_MAINTAINER_MODE=bool
Whether to enable a MySQL maintainer-specific development
environment. If enabled, this option causes compiler
warnings to become errors.
* -DMYSQL_PROJECT_NAME=name
For Windows or OS X, the project name to incorporate into
the project file name. This option was added in MySQL
5.5.21.
* -DMYSQL_TCP_PORT=port_num
The port number on which the server listens for TCP/IP
connections. The default is 3306.
This value can be set at server startup with the --port
option.
* -DMYSQL_UNIX_ADDR=file_name
The Unix socket file path on which the server listens for
socket connections. This must be an absolute path name.
The default is /tmp/mysql.sock.
This value can be set at server startup with the --socket
option.
* -DWITH_ASAN=bool
Whether to enable AddressSanitizer, for compilers that
support it. The default is off. This option was added in
MySQL 5.5.35.
* -DWITH_DEBUG=bool
Whether to include debugging support.
Configuring MySQL with debugging support enables you to
use the --debug="d,parser_debug" option when you start
the server. This causes the Bison parser that is used to
process SQL statements to dump a parser trace to the
server's standard error output. Typically, this output is
written to the error log.
* -DWITH_EMBEDDED_SERVER=bool
Whether to build the libmysqld embedded server library.
* -DWITH_EMBEDDED_SHARED_LIBRARY=bool
Whether to build a shared libmysqld embedded server
library. This option was added in MySQL 5.5.37.
* -DWITH_EXTRA_CHARSETS=name
Which extra character sets to include:
+ all: All character sets. This is the default.
+ complex: Complex character sets.
+ none: No extra character sets.
* -DWITH_LIBEDIT=bool
Whether to use the libedit library bundled with the
distribution.
* -DWITH_LIBWRAP=bool
Whether to include libwrap (TCP wrappers) support.
* -DWITH_READLINE=bool
Whether to use the readline library bundled with the
distribution.
* -DWITH_SSL=ssl_type
The type of SSL support to include, if any:
+ no: No SSL support. This is the default.
+ yes: Use the system SSL library if present, else the
library bundled with the distribution.
+ bundled: Use the SSL library bundled with the
distribution.
+ system: Use the system SSL library.
For information about using SSL support, see Section
6.3.9, "Using SSL for Secure Connections."
* -DWITH_UNIXODBC=1
Enables unixODBC support, for Connector/ODBC.
* -DWITH_VALGRIND=bool
Whether to compile in the Valgrind header files, which
exposes the Valgrind API to MySQL code. The default is
OFF.
To generate a Valgrind-aware debug build,
-DWITH_VALGRIND=1 normally is combined with
-DWITH_DEBUG=1. See Building Debug Configurations
(http://dev.mysql.com/doc/internals/en/debug-configuratio
ns.html).
* -DWITH_ZLIB=zlib_type
Some features require that the server be built with
compression library support, such as the COMPRESS() and
UNCOMPRESS() functions, and compression of the
client/server protocol. The WITH_ZLIB indicates the
source of zlib support:
+ bundled: Use the zlib library bundled with the
distribution.
+ system: Use the system zlib library. This is the
default.
* -DWITHOUT_SERVER=bool
Whether to build without the MySQL server. The default is
OFF, which does build the server.
Compiler Flags
* -DCMAKE_C_FLAGS="flags"
Flags for the C Compiler.
* -DCMAKE_CXX_FLAGS="flags"
Flags for the C++ Compiler.
To specify your own C and C++ compiler flags, for flags that
do not affect optimization, use the CMAKE_C_FLAGS and
CMAKE_CXX_FLAGS CMake options.
When providing your own compiler flags, you might want to
specify CMAKE_BUILD_TYPE as well.
For example, to create a 32-bit release build on a 64-bit
Linux machine, do this:
shell> mkdir bld
shell> cd bld
shell> cmake .. -DCMAKE_C_FLAGS=-m32 \
-DCMAKE_CXX_FLAGS=-m32 \
-DCMAKE_BUILD_TYPE=RelWithDebInfo
If you set flags that affect optimization (-Onumber), you
must set the CMAKE_C_FLAGS_build_type and/or
CMAKE_CXX_FLAGS_build_type options, where build_type
corresponds to the CMAKE_BUILD_TYPE value. To specify a
different optimization for the default build type
(RelWithDebInfo) set the CMAKE_C_FLAGS_RELWITHDEBINFO and
CMAKE_CXX_FLAGS_RELWITHDEBINFO options. For example, to
compile on Linux with -O3 and with debug symbols, do this:
shell> cmake .. -DCMAKE_C_FLAGS_RELWITHDEBINFO="-O3 -g" \
-DCMAKE_CXX_FLAGS_RELWITHDEBINFO="-O3 -g"
CMake Options for Compiling MySQL Cluster
The following options are for use when building MySQL Cluster
NDB 7.2 or later. These options are supported only with the
MySQL Cluster NDB 7.2 and later MySQL Cluster sources; they
are not supported when using sources from the MySQL 5.5
Server tree.
* -DMEMCACHED_HOME=dir_name
Perform the build using the memcached (version 1.6 or
later) installed in the system directory indicated by
dir_name. Files from this installation that are used in
the build include the memcached binary, header files, and
libraries, as well as the memcached_utilities library and
the header file engine_testapp.h.
You must leave this option unset when building
ndbmemcache using the bundled memcached sources
(WITH_BUNDLED_MEMCACHED option); in other words, the
bundled sources are used by default).
This option was added in MySQL Cluster NDB 7.2.2.
While additional CMake options---such as for SASL
authorization and for providing dtrace support---are
available for use when compiling memcached from external
sources, these options are currently not enabled for the
memcached sources bundled with MySQL Cluster.
* -DWITH_BUNDLED_LIBEVENT={ON|OFF}
Use the libevent included in the MySQL Cluster sources
when building MySQL Cluster with ndbmemcached support
(MySQL Cluster NDB 7.2.2 and later). Enabled by default.
OFF causes the system's libevent to be used instead.
* -DWITH_BUNDLED_MEMCACHED={ON|OFF}
Build the memcached sources included in the MySQL Cluster
source tree (MySQL Cluster NDB 7.2.3 and later), then use
the resulting memcached server when building the
ndbmemcache engine. In this case, make install places the
memcached binary in the installation bin directory, and
the ndbmemcache engine shared object file ndb_engine.so
in the installation lib directory.
This option is ON by default.
* -DWITH_CLASSPATH=path
Sets the classpath for building MySQL Cluster Connector
for Java. The default is empty. In MySQL Cluster NDB
7.2.9 and later, this option is ignored if
-DWITH_NDB_JAVA=OFF is used.
* -DWITH_ERROR_INSERT={ON|OFF}
Enables error injection in the NDB kernel. For testing
only; not intended for use in building production
binaries. The default is OFF.
* -DWITH_NDBCLUSTER_STORAGE_ENGINE={ON|OFF}
Build and link in support for the NDB (NDBCLUSTER)
storage engine in mysqld. The default is ON.
* -DWITH_NDBCLUSTER={ON|OFF}
This is an alias for WITH_NDBCLUSTER_STORAGE_ENGINE.
* -DWITH_NDBMTD={ON|OFF}
Build the multi-threaded data node executable ndbmtd. The
default is ON.
* -DWITH_NDB_BINLOG={ON|OFF}
Enable binary logging by default in the mysqld built
using this option. ON by default.
* -DWITH_NDB_DEBUG={ON|OFF}
Enable building the debug versions of the MySQL Cluster
binaries. OFF by default.
* -DWITH_NDB_JAVA={ON|OFF}
Enable building MySQL Cluster with Java support,
including ClusterJ.
This option was added in MySQL Cluster NDB 7.2.9, and is
ON by default. If you do not wish to compile MySQL
Cluster with Java support, you must disable it explicitly
by specifying -DWITH_NDB_JAVA=OFF when running CMake.
Otherwise, if Java cannot be found, configuration of the
build fails.
* -DWITH_NDB_PORT=port
Causes the MySQL Cluster management server (ndb_mgmd)
that is built to use this port by default. If this option
is unset, the resulting management server tries to use
port 1186 by default.
* -DWITH_NDB_TEST={ON|OFF}
If enabled, include a set of NDB API test programs. The
default is OFF.
2.9.5 Dealing with Problems Compiling MySQL
The solution to many problems involves reconfiguring. If you
do reconfigure, take note of the following:
* If CMake is run after it has previously been run, it may
use information that was gathered during its previous
invocation. This information is stored in CMakeCache.txt.
When CMake starts up, it looks for that file and reads
its contents if it exists, on the assumption that the
information is still correct. That assumption is invalid
when you reconfigure.
* Each time you run CMake, you must run make again to
recompile. However, you may want to remove old object
files from previous builds first because they were
compiled using different configuration options.
To prevent old object files or configuration information from
being used, run the following commands before re-running
CMake:
On Unix:
shell> make clean
shell> rm CMakeCache.txt
On Windows:
shell> devenv MySQL.sln /clean
shell> del CMakeCache.txt
If you build outside of the source tree, remove and recreate
your build directory before re-running CMake. For
instructions on building outside of the source tree, see How
to Build MySQL Server with CMake
(http://dev.mysql.com/doc/internals/en/cmake.html).
On some systems, warnings may occur due to differences in
system include files. The following list describes other
problems that have been found to occur most often when
compiling MySQL:
* To define which C and C++ compilers to use, you can
define the CC and CXX environment variables. For example:
shell> CC=gcc
shell> CXX=g++
shell> export CC CXX
To specify your own C and C++ compiler flags, use the
CMAKE_C_FLAGS and CMAKE_CXX_FLAGS CMake options. See
Section 2.9.4, "."
To see what flags you might need to specify, invoke
mysql_config with the --cflags option.
* To see what commands are executed during the compile
stage, after using CMake to configure MySQL, run make
VERBOSE=1 rather than just make.
* If compilation fails, check whether the
MYSQL_MAINTAINER_MODE option is enabled. This mode causes
compiler warnings to become errors, so disabling it may
enable compilation to proceed.
* If your compile fails with errors such as any of the
following, you must upgrade your version of make to GNU
make:
make: Fatal error in reader: Makefile, line 18:
Badly formed macro assignment
Or:
make: file `Makefile' line 18: Must be a separator (:
Or:
pthread.h: No such file or directory
Solaris and FreeBSD are known to have troublesome make
programs.
GNU make 3.75 is known to work.
* The sql_yacc.cc file is generated from sql_yacc.yy.
Normally, the build process does not need to create
sql_yacc.cc because MySQL comes with a pregenerated copy.
However, if you do need to re-create it, you might
encounter this error:
"sql_yacc.yy", line xxx fatal: default action causes potential...
This is a sign that your version of yacc is deficient.
You probably need to install a recent version of bison
(the GNU version of yacc) and use that instead.
Versions of bison older than 1.75 may report this error:
sql_yacc.yy:#####: fatal error: maximum table size (32767) exceeded
The maximum table size is not actually exceeded; the
error is caused by bugs in older versions of bison.
For information about acquiring or updating tools, see the
system requirements in Section 2.9, "Installing MySQL from
Source."
2.9.6 MySQL Configuration and Third-Party Tools
Third-party tools that need to determine the MySQL version
from the MySQL source can read the VERSION file in the
top-level source directory. The file lists the pieces of the
version separately. For example, if the version is MySQL
5.7.4-m14, the file looks like this:
MYSQL_VERSION_MAJOR=5
MYSQL_VERSION_MINOR=7
MYSQL_VERSION_PATCH=4
MYSQL_VERSION_EXTRA=-m14
If the source is not for a General Availablility (GA)
release, the MYSQL_VERSION_EXTRA value will be nonempty. For
the example, the value corresponds to Milestone 14.
To construct a five-digit number from the version components,
use this formula:
MYSQL_VERSION_MAJOR*10000 + MYSQL_VERSION_MINOR*100 + MYSQL_VERSION_PA
TCH
2.10 Postinstallation Setup and Testing
This section discusses tasks that you should perform after
installing MySQL:
* If necessary, initialize the data directory and create
the MySQL grant tables. For some MySQL installation
methods, data directory initialization may be done for
you automatically:
+ Installation on Windows
+ Installation on Linux using a server RPM
distribution.
+ Installation using the native packaging system on
many platforms, including Debian Linux, Ubuntu
Linux, Gentoo Linux, and others.
+ Installation on OS X using a DMG distribution.
For other platforms and installation types, including
installation from generic binary and source
distributions, you must initialize the data directory
yourself. For instructions, see Section 2.10.1,
"Initializing the Data Directory."
* For instructions, see Section 2.10.2, "Starting the
Server," and Section 2.10.3, "Testing the Server."
* Assign passwords to any initial accounts in the grant
tables, if that was not already done during data
directory initialization. Passwords prevent unauthorized
access to the MySQL server. You may also wish to restrict
access to test databases. For instructions, see Section
2.10.4, "Securing the Initial MySQL Accounts."
* Optionally, arrange for the server to start and stop
automatically when your system starts and stops. For
instructions, see Section 2.10.5, "Starting and Stopping
MySQL Automatically."
* Optionally, populate time zone tables to enable
recognition of named time zones. For instructions, see
Section 10.6, "MySQL Server Time Zone Support."
When you are ready to create additional user accounts, you
can find information on the MySQL access control system and
account management in Section 6.2, "The MySQL Access
Privilege System," and Section 6.3, "MySQL User Account
Management."
2.10.1 Initializing the Data Directory
After installing MySQL, you must initialize the data
directory, including the tables in the mysql system database.
For some MySQL installation methods, data directory
initialization may be done automatically, as described in
Section 2.10, "Postinstallation Setup and Testing." For other
installation methods, including installation from generic
binary and source distributions, you must initialize the data
directory yourself.
This section describes how to initialize the data directory
on Unix and Unix-like systems. (For Windows, see Section
2.3.9, "Windows Postinstallation Procedures.") For some
suggested commands that you can use to test whether the
server is accessible and working properly, see Section
2.10.3, "Testing the Server."
In the examples shown here, the server runs under the user ID
of the mysql login account. This assumes that such an account
exists. Either create the account if it does not exist, or
substitute the name of a different existing login account
that you plan to use for running the server. For information
about creating the account, see Creating a mysql System User
and Group, in Section 2.2, "Installing MySQL on Unix/Linux
Using Generic Binaries."
1. Change location into the top-level directory of your
MySQL installation, represented here by BASEDIR:
shell> cd BASEDIR
BASEDIR is likely to be something like /usr/local/mysql
or /usr/local. The following steps assume that you have
changed location to this directory.
You will find several files and subdirectories in the
BASEDIR directory. The most important for installation
purposes are the bin and scripts subdirectories, which
contain the server as well as client and utility
programs.
2. If necessary, ensure that the distribution contents are
accessible to mysql. If you installed the distribution as
mysql, no further action is required. If you installed
the distribution as root, its contents will be owned by
root. Change its ownership to mysql by executing the
following commands as root in the installation directory.
The first command changes the owner attribute of the
files to the mysql user. The second changes the group
attribute to the mysql group.
shell> chown -R mysql .
shell> chgrp -R mysql .
3. If necessary, initialize the data directory, including
the mysql database containing the initial MySQL grant
tables that determine how users are permitted to connect
to the server.
Typically, data directory initialization need be done
only the first time you install MySQL. If you are
upgrading an existing installation, you should run
mysql_upgrade instead (see Section 4.4.7, "mysql_upgrade
--- Check and Upgrade MySQL Tables"). However, the
command that initializes the data directory does not
overwrite any existing privilege tables, so it should be
safe to run in any circumstances.
shell> scripts/mysql_install_db --user=mysql
It is important to make sure that the database
directories and files are owned by the mysql login
account so that the server has read and write access to
them when you run it later. To ensure this if you run
mysql_install_db as root, include the --user option as
shown. Otherwise, you should execute the program while
logged in as mysql, in which case you can omit the --user
option from the command.
The mysql_install_db command creates the server's data
directory. Under the data directory, it creates
directories for the mysql database that holds the grant
tables and the test database that you can use to test
MySQL. The program also creates privilege table entries
for the initial account or accounts. test_. For a
complete listing and description of the grant tables, see
Section 6.2, "The MySQL Access Privilege System."
It might be necessary to specify other options such as
--basedir or --datadir if mysql_install_db does not
identify the correct locations for the installation
directory or data directory. For example:
shell> scripts/mysql_install_db --user=mysql \
--basedir=/opt/mysql/mysql \
--datadir=/opt/mysql/mysql/data
If you do not want to have the test database, you can
remove it after starting the server, using the
instructions in Section 2.10.4, "Securing the Initial
MySQL Accounts."
If you have trouble with mysql_install_db at this point,
see Section 2.10.1.1, "Problems Running
mysql_install_db."
4. After initializing the data directory, you can establish
the final installation ownership settings. To leave the
installation owned by mysql, no action is required here.
Otherwise, most of the MySQL installation can be owned by
root if you like. The exception is that the data
directory must be owned by mysql. To accomplish this, run
the following commands as root in the installation
directory. For some distribution types, the data
directory might be named var rather than data; adjust the
second command accordingly.
shell> chown -R root .
shell> chown -R mysql data
If the plugin directory (the directory named by the
plugin_dir system variable) is writable by the server, it
may be possible for a user to write executable code to a
file in the directory using SELECT ... INTO DUMPFILE.
This can be prevented by making the plugin directory read
only to the server or by setting the secure_file_priv
system variable at server startup to a directory where
SELECT writes can be performed safely.
5. If you installed MySQL using a source distribution, you
may want to optionally copy one of the provided
configuration files from the support-files directory into
your /etc directory. There are different sample
configuration files for different use cases, server
types, and CPU and RAM configurations. To use one of
these standard files, copy it to /etc/my.cnf, or
/etc/mysql/my.cnf and edit and check the configuration
before starting your MySQL server for the first time.
You can also create my.cnf yourself and place into it the
options the server should use at startup. See Section
5.1.2, "Server Configuration Defaults."
If you do not copy one of the standard configuration
files or create your own, the MySQL server starts with
its default settings.
6. If you want MySQL to start automatically when you boot
your machine, see Section 2.10.5, "Starting and Stopping
MySQL Automatically."
Data directory initialization creates time zone tables in the
mysql database but does not populate them. To do so, use the
instructions in Section 10.6, "MySQL Server Time Zone
Support."
2.10.1.1 Problems Running mysql_install_db
The purpose of the mysql_install_db program is to initialize
the data directory, including the tables in the mysql system
database. It does not overwrite existing MySQL privilege
tables, and it does not affect any other data.
To re-create your privilege tables, first stop the mysqld
server if it is running. Then rename the mysql directory
under the data directory to save it, and run
mysql_install_db. Suppose that your current directory is the
MySQL installation directory and that mysql_install_db is
located in the bin directory and the data directory is named
data. To rename the mysql database and re-run
mysql_install_db, use these commands.
shell> mv data/mysql data/mysql.old
shell> scripts/mysql_install_db --user=mysql
When you run mysql_install_db, you might encounter the
following problems:
* mysql_install_db fails to install the grant tables
You may find that mysql_install_db fails to install the
grant tables and terminates after displaying the
following messages:
Starting mysqld daemon with databases from XXXXXX
mysqld ended
In this case, you should examine the error log file very
carefully. The log should be located in the directory
XXXXXX named by the error message and should indicate why
mysqld did not start. If you do not understand what
happened, include the log when you post a bug report. See
Section 1.6, "How to Report Bugs or Problems."
* There is a mysqld process running
This indicates that the server is running, in which case
the grant tables have probably been created already. If
so, there is no need to run mysql_install_db at all
because it needs to be run only once, when you first
install MySQL.
* Installing a second mysqld server does not work when one
server is running
This can happen when you have an existing MySQL
installation, but want to put a new installation in a
different location. For example, you might have a
production installation, but you want to create a second
installation for testing purposes. Generally the problem
that occurs when you try to run a second server is that
it tries to use a network interface that is in use by the
first server. In this case, you should see one of the
following error messages:
Can't start server: Bind on TCP/IP port:
Address already in use
Can't start server: Bind on unix socket...
For instructions on setting up multiple servers, see
Section 5.3, "Running Multiple MySQL Instances on One
Machine."
* You do not have write access to the /tmp directory
If you do not have write access to create temporary files
or a Unix socket file in the default location (the /tmp
directory) or the TMPDIR environment variable, if it has
been set, an error occurs when you run mysql_install_db
or the mysqld server.
You can specify different locations for the temporary
directory and Unix socket file by executing these
commands prior to starting mysql_install_db or mysqld,
where some_tmp_dir is the full path name to some
directory for which you have write permission:
shell> TMPDIR=/some_tmp_dir/
shell> MYSQL_UNIX_PORT=/some_tmp_dir/mysql.sock
shell> export TMPDIR MYSQL_UNIX_PORT
Then you should be able to run mysql_install_db and start
the server with these commands:
shell> scripts/mysql_install_db --user=mysql
shell> bin/mysqld_safe --user=mysql &
If mysql_install_db is located in the scripts directory,
modify the first command to scripts/mysql_install_db.
See Section B.5.4.5, "How to Protect or Change the MySQL
Unix Socket File," and Section 2.12, "Environment
Variables."
There are some alternatives to running the mysql_install_db
program provided in the MySQL distribution:
* If you want the initial privileges to be different from
the standard defaults, use account-management statements
such as CREATE USER, GRANT, and REVOKE to change the
privileges after the grant tables have been set up. In
other words, run mysql_install_db, and then use mysql -u
root mysql to connect to the server as the MySQL root
user so that you can issue the necessary statements. (See
Section 13.7.1, "Account Management Statements.")
To install MySQL on several machines with the same
privileges, put the CREATE USER, GRANT, and REVOKE
statements in a file and execute the file as a script
using mysql after running mysql_install_db. For example:
shell> scripts/mysql_install_db --user=mysql
shell> bin/mysql -u root < your_script_file
This enables you to avoid issuing the statements manually
on each machine.
* It is possible to re-create the grant tables completely
after they have previously been created. You might want
to do this if you are just learning how to use CREATE
USER, GRANT, and REVOKE and have made so many
modifications after running mysql_install_db that you
want to wipe out the tables and start over.
To re-create the grant tables, stop the server if it is
running and remove the mysql database directory. Then run
mysql_install_db again.
2.10.2 Starting the Server
This section describes how start the server on Unix and
Unix-like systems. (For Windows, see Section 2.3.7.4,
"Starting the Server for the First Time.") For some suggested
commands that you can use to test whether the server is
accessible and working properly, see Section 2.10.3, "Testing
the Server."
Start the MySQL server like this:
shell> bin/mysqld_safe --user=mysql &
It is important that the MySQL server be run using an
unprivileged (non-root) login account. To ensure this if you
run mysqld_safe as root, include the --user option as shown.
Otherwise, execute the program while logged in as mysql, in
which case you can omit the --user option from the command.
For further instructions for running MySQL as an unprivileged
user, see Section 6.1.5, "How to Run MySQL as a Normal User."
If the command fails immediately and prints mysqld ended,
look for information in the error log (which by default is
the host_name.err file in the data directory).
If the server is unable to access the data directory it
starts or read the grant tables in the mysql database, it
writes a message to its error log. Such problems can occur if
you neglected to create the grant tables by initializing the
data directory before proceeding to this step, or if you ran
the command that initializes the data directory without the
--user option. Remove the data directory and run the command
with the --user option.
If you have other problems starting the server, see Section
2.10.2.1, "Troubleshooting Problems Starting the MySQL
Server." For more information about mysqld_safe, see Section
4.3.2, "mysqld_safe --- MySQL Server Startup Script."
You can set up new accounts using the bin/mysql_setpermission
script if you install the DBI and DBD::mysql Perl modules.
See Section 4.6.13, "mysql_setpermission --- Interactively
Set Permissions in Grant Tables." For Perl module
installation instructions, see Section 2.13, "Perl
Installation Notes."
If you would like to use mysqlaccess and have the MySQL
distribution in some nonstandard location, you must change
the location where mysqlaccess expects to find the mysql
client. Edit the bin/mysqlaccess script at approximately line
18. Search for a line that looks like this:
$MYSQL = '/usr/local/bin/mysql'; # path to mysql executable
Change the path to reflect the location where mysql actually
is stored on your system. If you do not do this, a Broken
pipe error will occur when you run mysqlaccess.
2.10.2.1 Troubleshooting Problems Starting the MySQL Server
This section provides troubleshooting suggestions for
problems starting the server. For additional suggestions for
Windows systems, see Section 2.3.8, "Troubleshooting a
Microsoft Windows MySQL Server Installation."
If you have problems starting the server, here are some
things to try:
* Check the error log to see why the server does not start.
* Specify any special options needed by the storage engines
you are using.
* Make sure that the server knows where to find the data
directory.
* Make sure that the server can access the data directory.
The ownership and permissions of the data directory and
its contents must be set such that the server can read
and modify them.
* Verify that the network interfaces the server wants to
use are available.
Some storage engines have options that control their
behavior. You can create a my.cnf file and specify startup
options for the engines that you plan to use. If you are
going to use storage engines that support transactional
tables (InnoDB, NDB), be sure that you have them configured
the way you want before starting the server:
If you are using InnoDB tables, see Section 14.6, "InnoDB
Configuration."
Storage engines will use default option values if you specify
none, but it is recommended that you review the available
options and specify explicit values for those for which the
defaults are not appropriate for your installation.
When the mysqld server starts, it changes location to the
data directory. This is where it expects to find databases
and where it expects to write log files. The server also
writes the pid (process ID) file in the data directory.
The data directory location is hardwired in when the server
is compiled. This is where the server looks for the data
directory by default. If the data directory is located
somewhere else on your system, the server will not work
properly. You can determine what the default path settings
are by invoking mysqld with the --verbose and --help options.
If the default locations do not match the MySQL installation
layout on your system, you can override them by specifying
options to mysqld or mysqld_safe on the command line or in an
option file.
To specify the location of the data directory explicitly, use
the --datadir option. However, normally you can tell mysqld
the location of the base directory under which MySQL is
installed and it looks for the data directory there. You can
do this with the --basedir option.
To check the effect of specifying path options, invoke mysqld
with those options followed by the --verbose and --help
options. For example, if you change location into the
directory where mysqld is installed and then run the
following command, it shows the effect of starting the server
with a base directory of /usr/local:
shell> ./mysqld --basedir=/usr/local --verbose --help
You can specify other options such as --datadir as well, but
--verbose and --help must be the last options.
Once you determine the path settings you want, start the
server without --verbose and --help.
If mysqld is currently running, you can find out what path
settings it is using by executing this command:
shell> mysqladmin variables
Or:
shell> mysqladmin -h host_name variables
host_name is the name of the MySQL server host.
If you get Errcode 13 (which means Permission denied) when
starting mysqld, this means that the privileges of the data
directory or its contents do not permit server access. In
this case, you change the permissions for the involved files
and directories so that the server has the right to use them.
You can also start the server as root, but this raises
security issues and should be avoided.
Change location into the data directory and check the
ownership of the data directory and its contents to make sure
the server has access. For example, if the data directory is
/usr/local/mysql/var, use this command:
shell> ls -la /usr/local/mysql/var
If the data directory or its files or subdirectories are not
owned by the login account that you use for running the
server, change their ownership to that account. If the
account is named mysql, use these commands:
shell> chown -R mysql /usr/local/mysql/var
shell> chgrp -R mysql /usr/local/mysql/var
Even with correct ownership, MySQL might fail to start up if
there is other security software running on your system that
manages application access to various parts of the file
system. In this case, reconfigure that software to enable
mysqld to access the directories it uses during normal
operation.
If the server fails to start up correctly, check the error
log. Log files are located in the data directory (typically
C:\Program Files\MySQL\MySQL Server 5.5\data on Windows,
/usr/local/mysql/data for a Unix/Linux binary distribution,
and /usr/local/var for a Unix/Linux source distribution).
Look in the data directory for files with names of the form
host_name.err and host_name.log, where host_name is the name
of your server host. Then examine the last few lines of these
files. You can use tail to display them:
shell> tail host_name.err
shell> tail host_name.log
The error log should contain information that indicates why
the server could not start.
If either of the following errors occur, it means that some
other program (perhaps another mysqld server) is using the
TCP/IP port or Unix socket file that mysqld is trying to use:
Can't start server: Bind on TCP/IP port: Address already in use
Can't start server: Bind on unix socket...
Use ps to determine whether you have another mysqld server
running. If so, shut down the server before starting mysqld
again. (If another server is running, and you really want to
run multiple servers, you can find information about how to
do so in Section 5.3, "Running Multiple MySQL Instances on
One Machine.")
If no other server is running, try to execute the command
telnet your_host_name tcp_ip_port_number. (The default MySQL
port number is 3306.) Then press Enter a couple of times. If
you do not get an error message like telnet: Unable to
connect to remote host: Connection refused, some other
program is using the TCP/IP port that mysqld is trying to
use. You will need to track down what program this is and
disable it, or else tell mysqld to listen to a different port
with the --port option. In this case, you will also need to
specify the port number for client programs when connecting
to the server using TCP/IP.
Another reason the port might be inaccessible is that you
have a firewall running that blocks connections to it. If so,
modify the firewall settings to permit access to the port.
If the server starts but you cannot connect to it, you should
make sure that you have an entry in /etc/hosts that looks
like this:
127.0.0.1 localhost
If you cannot get mysqld to start, you can try to make a
trace file to find the problem by using the --debug option.
See Section 24.5.3, "The DBUG Package."
2.10.3 Testing the Server
After the data directory is initialized and you have started
the server, perform some simple tests to make sure that it
works satisfactorily. This section assumes that your current
location is the MySQL installation directory and that it has
a bin subdirectory containing the MySQL programs used here.
If that is not true, adjust the command path names
accordingly.
Alternatively, add the bin directory to your PATH environment
variable setting. That enables your shell (command
interpreter) to find MySQL programs properly, so that you can
run a program by typing only its name, not its path name. See
Section 4.2.10, "Setting Environment Variables."
Use mysqladmin to verify that the server is running. The
following commands provide simple tests to check whether the
server is up and responding to connections:
shell> bin/mysqladmin version
shell> bin/mysqladmin variables
If you cannot connect to the server, specify a -u root option
to connect as root. If you have assigned a password for the
root account already, you'll also need to specify -p on the
command line and enter the password when prompted. For
example:
shell> bin/mysqladmin -u root -p version
Enter password: (enter root password here)
The output from mysqladmin version varies slightly depending
on your platform and version of MySQL, but should be similar
to that shown here:
shell> bin/mysqladmin version
mysqladmin Ver 14.12 Distrib 5.5.47, for pc-linux-gnu on i686
...
Server version 5.5.47
Protocol version 10
Connection Localhost via UNIX socket
UNIX socket /var/lib/mysql/mysql.sock
Uptime: 14 days 5 hours 5 min 21 sec
Threads: 1 Questions: 366 Slow queries: 0
Opens: 0 Flush tables: 1 Open tables: 19
Queries per second avg: 0.000
To see what else you can do with mysqladmin, invoke it with
the --help option.
Verify that you can shut down the server (include a -p option
if the root account has a password already):
shell> bin/mysqladmin -u root shutdown
Verify that you can start the server again. Do this by using
mysqld_safe or by invoking mysqld directly. For example:
shell> bin/mysqld_safe --user=mysql &
If mysqld_safe fails, see Section 2.10.2.1, "Troubleshooting
Problems Starting the MySQL Server."
Run some simple tests to verify that you can retrieve
information from the server. The output should be similar to
that shown here.
Use mysqlshow to see what databases exist:
shell> bin/mysqlshow
+--------------------+
| Databases |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
The list of installed databases may vary, but will always
include the minimum of mysql and information_schema.
If you specify a database name, mysqlshow displays a list of
the tables within the database:
shell> bin/mysqlshow mysql
Database: mysql
+---------------------------+
| Tables |
+---------------------------+
| columns_priv |
| db |
| event |
| func |
| general_log |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| ndb_binlog_index |
| plugin |
| proc |
| procs_priv |
| proxies_priv |
| servers |
| slow_log |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
Use the mysql program to select information from a table in
the mysql database:
shell> bin/mysql -e "SELECT User, Host, plugin FROM mysql.user" mysql
+------+-----------+-----------------------+
| User | Host | plugin |
+------+-----------+-----------------------+
| root | localhost | mysql_native_password |
+------+-----------+-----------------------+
At this point, your server is running and you can access it.
To tighten security if you have not yet assigned passwords to
the initial account or accounts, follow the instructions in
Section 2.10.4, "Securing the Initial MySQL Accounts."
For more information about mysql, mysqladmin, and mysqlshow,
see Section 4.5.1, "mysql --- The MySQL Command-Line Tool,"
Section 4.5.2, "mysqladmin --- Client for Administering a
MySQL Server," and Section 4.5.6, "mysqlshow --- Display
Database, Table, and Column Information."
2.10.4 Securing the Initial MySQL Accounts
Part of the MySQL installation process involves initializing
the data directory, including the mysql database containing
the grant tables that define the initial MySQL accounts. For
details, see Section 2.10, "Postinstallation Setup and
Testing."
The mysql.user grant table defines the initial MySQL user
accounts and their access privileges:
* Some accounts have the user name root. These are
superuser accounts that have all privileges and can do
anything. If these root accounts have empty passwords,
anyone can connect to the MySQL server as root without a
password and be granted all privileges.
+ On Windows, root accounts are created that permit
connections from the local host only. Connections
can be made by specifying the host name localhost,
the IP address 127.0.0.1, or the IPv6 address ::1.
If the user selects the Enable root access from
remote machines option during installation, the
Windows installer creates another root account that
permits connections from any host.
+ On Unix, each root account permits connections from
the local host. Connections can be made by
specifying the host name localhost, the IP address
127.0.0.1, the IPv6 address ::1, or the actual host
name or IP address.
An attempt to connect to the host 127.0.0.1 normally
resolves to the localhost account. However, this fails if
the server is run with the --skip-name-resolve option, so
the 127.0.0.1 account is useful in that case. The ::1
account is used for IPv6 connections.
* If accounts for anonymous users were created, these have
an empty user name. The anonymous accounts have no
password, so anyone can use them to connect to the MySQL
server.
+ On Windows, there is one anonymous account that
permits connections from the local host. Connections
can be made by specifying a host name of localhost.
+ On Unix, each anonymous account permits connections
from the local host. Connections can be made by
specifying a host name of localhost for one of the
accounts, or the actual host name or IP address for
the other.
+ The 'root'@'localhost' account also has a row in the
mysql.proxies_priv table that enables granting the
PROXY privilege for ''@'', that is, for all users
and all hosts. This enables root to set up proxy
users, as well as to delegate to other accounts the
authority to set up proxy users. See Section 6.3.8,
"Proxy Users."
To display which accounts exist in the mysql.user table and
check whether their passwords are empty, use the following
statement:
mysql> SELECT User, Host, Password FROM mysql.user;
+------+--------------------+----------+
| User | Host | Password |
+------+--------------------+----------+
| root | localhost | |
| root | myhost.example.com | |
| root | 127.0.0.1 | |
| root | ::1 | |
| | localhost | |
| | myhost.example.com | |
+------+--------------------+----------+
This output indicates that there are several root and
anonymous-user accounts, none of which have passwords. The
output might differ on your system, but the presence of
accounts with empty passwords means that your MySQL
installation is unprotected until you do something about it:
* Assign a password to each MySQL root account that does
not have one.
* To prevent clients from connecting as anonymous users
without a password, either assign a password to each
anonymous account or remove the accounts.
In addition, the mysql.db table contains rows that permit all
accounts to access the test database and other databases with
names that start with test_. This is true even for accounts
that otherwise have no special privileges such as the default
anonymous accounts. This is convenient for testing but
inadvisable on production servers. Administrators who want
database access restricted only to accounts that have
permissions granted explicitly for that purpose should remove
these mysql.db table rows.
The following instructions describe how to set up passwords
for the initial MySQL accounts, first for the root accounts,
then for the anonymous accounts. The instructions also cover
how to remove anonymous accounts, should you prefer not to
permit anonymous access at all, and describe how to remove
permissive access to test databases. Replace newpwd in the
examples with the password that you want to use. Replace
host_name with the name of the server host. You can determine
this name from the output of the preceding SELECT statement.
For the output shown, host_name is myhost.example.com.
Note
For additional information about setting passwords, see
Section 6.3.5, "Assigning Account Passwords." If you forget
your root password after setting it, see Section B.5.4.1,
"How to Reset the Root Password."
To set up additional accounts, see Section 6.3.2, "Adding
User Accounts."
You might want to defer setting the passwords until later, to
avoid the need to specify them while you perform additional
setup or testing. However, be sure to set them before using
your installation for production purposes.
Note
On Windows, you can also perform the process described in
this section using the Configuration Wizard (see Section
2.3.6.11, "The Security Options Dialog"). On all platforms,
the MySQL distribution includes mysql_secure_installation, a
command-line utility that automates much of the process of
securing a MySQL installation. MySQL Workbench is available
on all platforms, and also offers the ability to manage user
accounts (see Chapter 26, "MySQL Workbench" ).
Assigning root Account Passwords
A root account password can be set several ways. The
following discussion demonstrates three methods:
* Use the SET PASSWORD statement
* Use the UPDATE statement
* Use the mysqladmin command-line client program
To assign passwords using SET PASSWORD, connect to the server
as root and issue a SET PASSWORD statement for each root
account listed in the mysql.user table.
For Windows, do this:
shell> mysql -u root
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'127.0.0.1' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'::1' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'%' = PASSWORD('newpwd');
The last statement is unnecessary if the mysql.user table has
no root account with a host value of %.
For Unix, do this:
shell> mysql -u root
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'127.0.0.1' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'::1' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR 'root'@'host_name' = PASSWORD('newpwd');
You can also use a single statement that assigns a password
to all root accounts by using UPDATE to modify the mysql.user
table directly. This method works on any platform:
shell> mysql -u root
mysql> UPDATE mysql.user SET Password = PASSWORD('newpwd')
-> WHERE User = 'root';
mysql> FLUSH PRIVILEGES;
The FLUSH statement causes the server to reread the grant
tables. Without it, the password change remains unnoticed by
the server until you restart it.
To assign passwords to the root accounts using mysqladmin,
execute the following commands:
shell> mysqladmin -u root password "newpwd"
shell> mysqladmin -u root -h host_name password "newpwd"
Those commands apply both to Windows and to Unix. The double
quotation marks around the password are not always necessary,
but you should use them if the password contains spaces or
other characters that are special to your command
interpreter.
The mysqladmin method of setting the root account passwords
does not work for the 'root'@'127.0.0.1' or 'root'@'::1'
account. Use the SET PASSWORD method shown earlier.
After the root passwords have been set, you must supply the
appropriate password whenever you connect as root to the
server. For example, to shut down the server with mysqladmin,
use this command:
shell> mysqladmin -u root -p shutdown
Enter password: (enter root password here)
The mysql commands in the following instructions include a -p
option based on the assumption that you have assigned the
root account passwords using the preceding instructions and
must specify that password when connecting to the server.
Assigning Anonymous Account Passwords
To assign passwords to the anonymous accounts, connect to the
server as root, then use either SET PASSWORD or UPDATE.
To use SET PASSWORD on Windows, do this:
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> SET PASSWORD FOR ''@'localhost' = PASSWORD('newpwd');
To use SET PASSWORD on Unix, do this:
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> SET PASSWORD FOR ''@'localhost' = PASSWORD('newpwd');
mysql> SET PASSWORD FOR ''@'host_name' = PASSWORD('newpwd');
To set the anonymous-user account passwords with a single
UPDATE statement, do this (on any platform):
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> UPDATE mysql.user SET Password = PASSWORD('newpwd')
-> WHERE User = '';
mysql> FLUSH PRIVILEGES;
The FLUSH statement causes the server to reread the grant
tables. Without it, the password change remains unnoticed by
the server until you restart it.
Removing Anonymous Accounts
If you prefer to remove any anonymous accounts rather than
assigning them passwords, do so as follows on Windows:
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> DROP USER ''@'localhost';
On Unix, remove the anonymous accounts like this:
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> DROP USER ''@'localhost';
mysql> DROP USER ''@'host_name';
Securing Test Databases
By default, the mysql.db table contains rows that permit
access by any user to the test database and other databases
with names that start with test_. (These rows have an empty
User column value, which for access-checking purposes matches
any user name.) This means that such databases can be used
even by accounts that otherwise possess no privileges. If you
want to remove any-user access to test databases, do so as
follows:
shell> mysql -u root -p
Enter password: (enter root password here)
mysql> DELETE FROM mysql.db WHERE Db LIKE 'test%';
mysql> FLUSH PRIVILEGES;
The FLUSH statement causes the server to reread the grant
tables. Without it, the privilege change remains unnoticed by
the server until you restart it.
With the preceding change, only users who have global
database privileges or privileges granted explicitly for the
test database can use it. However, if you prefer that the
database not exist at all, drop it:
mysql> DROP DATABASE test;
2.10.5 Starting and Stopping MySQL Automatically
This section discusses methods for starting and stopping the
MySQL server.
Generally, you start the mysqld server in one of these ways:
* Invoke mysqld directly. This works on any platform.
* On Windows, you can set up a MySQL service that runs
automatically when Windows starts. See Section 2.3.7.7,
"Starting MySQL as a Windows Service."
* On Unix and Unix-like systems, you can invoke
mysqld_safe, which tries to determine the proper options
for mysqld and then runs it with those options. See
Section 4.3.2, "mysqld_safe --- MySQL Server Startup
Script."
* On systems that use System V-style run directories (that
is, /etc/init.d and run-level specific directories),
invoke mysql.server. This script is used primarily at
system startup and shutdown. It usually is installed
under the name mysql. The mysql.server script starts the
server by invoking mysqld_safe. See Section 4.3.3,
"mysql.server --- MySQL Server Startup Script."
* On OS X, install a launchd daemon to enable automatic
MySQL startup at system startup. The daemon starts the
server by invoking mysqld_safe. For details, see Section
2.4.3, "Installing a MySQL Launch Daemon." A MySQL
Preference Pane also provides control for starting and
stopping MySQL through the System Preferences. See
Section 2.4.4, "Installing and Using the MySQL Preference
Pane."
* On Solaris/OpenSolaris, use the service management
framework (SMF) system to initiate and control MySQL
startup. For more information, see Section 2.7.2,
"Installing MySQL on OpenSolaris Using IPS."
The mysqld_safe and mysql.server scripts, Solaris/OpenSolaris
SMF, and the OS X Startup Item (or MySQL Preference Pane) can
be used to start the server manually, or automatically at
system startup time. mysql.server and the Startup Item also
can be used to stop the server.
The following table shows which option groups the server and
startup scripts read from option files.
Table 2.14 MySQL Startup Scripts and Supported Server Option
Groups
Script Option Groups
mysqld [mysqld], [server], [mysqld-major_version]
mysqld_safe [mysqld], [server], [mysqld_safe]
mysql.server [mysqld], [mysql.server], [server]
[mysqld-major_version] means that groups with names like
[mysqld-5.1] and [mysqld-5.5] are read by servers having
versions 5.1.x, 5.5.x, and so forth. This feature can be used
to specify options that can be read only by servers within a
given release series.
For backward compatibility, mysql.server also reads the
[mysql_server] group and mysqld_safe also reads the
[safe_mysqld] group. However, you should update your option
files to use the [mysql.server] and [mysqld_safe] groups
instead.
For more information on MySQL configuration files and their
structure and contents, see Section 4.2.6, "Using Option
Files."
2.11 Upgrading or Downgrading MySQL
This section describes the steps to upgrade or downgrade a
MySQL installation.
Upgrading is a common procedure, as you pick up bug fixes
within the same MySQL release series or significant features
between major MySQL releases. You perform this procedure
first on some test systems to make sure everything works
smoothly, and then on the production systems.
Downgrading is less common. Typically, you undo an upgrade
because of some compatibility or performance issue that
occurs on a production system, and was not uncovered during
initial upgrade verification on the test systems. As with the
upgrade procedure, perform and verify the downgrade procedure
on some test systems first, before using it on a production
system.
2.11.1 Upgrading MySQL
This section describes how to upgrade to a new MySQL version.
* Supported Upgrade Methods
* Supported Upgrade Paths
* Before You Begin
* Performing an In-place Upgrade
* Performing a Logical Upgrade
* Upgrade Troubleshooting
Supported Upgrade Methods
* In-place Upgrade: Involves shutting down the old MySQL
version, replacing the old MySQL binaries or packages
with the new ones, restarting MySQL on the existing data
directory, and running mysql_upgrade.
* Logical Upgrade: Involves exporting existing data from
the old MySQL version using mysqldump, installing the new
MySQL version, loading the dump file into the new MySQL
version, and running mysql_upgrade.
Note
MySQL recommends a mysqldump upgrade when upgrading from
a previous release. For example, use this method when
upgrading from 5.1 to 5.5.
For in-place and logical upgrade procedures, see Section
2.11.1, "," and Section 2.11.1, "."
If you run MySQL Server on Windows, see Section 2.3.10,
"Upgrading MySQL on Windows."
Supported Upgrade Paths
Unless otherwise documented, the following upgrade paths are
supported:
* Upgrading from a release series version to a newer
release series version is supported. For example,
upgrading from 5.5.45 to 5.5.46 is supported. Skipping
release series versions is also supported. For example,
upgrading from 5.5.44 to 5.5.46 is supported.
* Upgrading one release level is supported. For example,
upgrading from 5.1 to 5.5 is supported. Upgrading to the
latest release series version is recommended before
upgrading to the next release level. For example, upgrade
to the latest 5.1 release before upgrading to 5.5.
* Upgrading more than one release level is supported, but
only if you upgrade one release level at a time. For
example, if you currently are running MySQL 5.0 and wish
to upgrade to a newer series, upgrade to MySQL 5.1 first
before upgrading to MySQL 5.5, and so forth. For
information on upgrading to MySQL 5.1 see the MySQL 5.1
Reference Manual.
* Direct upgrades that skip a release level (for example,
upgrading directly from MySQL 5.0 to 5.5) are not
recommended or supported.
The following conditions apply to all upgrade paths:
* Upgrades between General Availability (GA) status
releases are supported.
* Upgrades between milestone releases (or from a milestone
release to a GA release) are not supported. For example,
upgrading from 5.5.7 to 5.5.8 is not supported, as 5.5.7
is not a GA status release.
* For upgrades between versions of a MySQL release series
that has reached GA status, you can move the MySQL format
files and data files between different versions on
systems with the same architecture. This is not
necessarily true for upgrades between milestone releases.
Use of milestone releases is at your own risk.
Before You Begin
Before upgrading, review the following information and
perform the recommended steps:
* Before upgrading, protect your data by creating a backup
of your current databases and log files. The backup
should include the mysql database, which contains the
MySQL system tables. See Section 7.2, "Database Backup
Methods."
* Review the Release Notes
(http://dev.mysql.com/doc/relnotes/mysql/5.5/en/) which
provide information about features that are new in the
MySQL 5.5 or differ from those found in earlier MySQL
releases. Some of these changes may result in
incompatibilities.
* Review Section 2.11.1.1, "Changes Affecting Upgrades to
5.5." This section describes changes that may require
action before or after upgrading.
* Check Section 2.11.3, "Checking Whether Tables or Indexes
Must Be Rebuilt," to see whether changes to table formats
or to character sets or collations were made between your
current version of MySQL and the version to which you are
upgrading. If such changes have resulted in an
incompatibility between MySQL versions, you will need to
upgrade the affected tables using the instructions in
Section 2.11.4, "Rebuilding or Repairing Tables or
Indexes."
* If you use replication, see Section 17.4.3, "Upgrading a
Replication Setup," for information on upgrading your
replication setup.
* If you use XA transactions with InnoDB, run XA RECOVER
before upgrading to check for uncommitted XA
transactions. If results are returned, either commit or
rollback the XA transactions by issuing an XA COMMIT or
XA ROLLBACK statement.
* If your MySQL installation contains a large amount of
data that might take a long time to convert after an
in-place upgrade, you might find it useful to create a
"dummy" database instance for assessing what conversions
might be needed and the work involved to perform them.
Make a copy of your MySQL instance that contains a full
copy of the mysql database, plus all other databases
without data. Run your upgrade procedure on this dummy
instance to see what actions might be needed so that you
can better evaluate the work involved when performing
actual data conversion on your original database
instance.
* Rebuilding and reinstalling the Perl DBD::mysql module
whenever you install or upgrade to a new release of MySQL
is recommended. The same applies to other MySQL
interfaces as well, such as PHP mysql extensions and the
Python MySQLdb module.
Performing an In-place Upgrade
This section describes how to perform an in-place upgrade.
Review Before you Begin before proceeding.
Note
If you upgrade an installation originally produced by
installing multiple RPM packages, upgrade all the packages,
not just some. For example, if you previously installed the
server and client RPMs, do not upgrade just the server RPM.
To perform an in-place upgrade:
1. Review the changes described in Section 2.11.1.1,
"Changes Affecting Upgrades to 5.5" for steps to be
performed before upgrading.
2. If you use InnoDB, configure MySQL to perform a slow
shutdown by setting innodb_fast_shutdown to 0. For
example:
shell> bin/mysql -u root -p password --execute="set global innodb_fast
_shutdown=0"
With a slow shutdown, InnoDB performs a full purge and
change buffer merge before shutting down, which ensures
that data files are fully prepared in case of file format
differences between releases.
3. Shut down the old MySQL server. For example:
shell> bin/mysqladmin -u root -p password shutdown
4. If you use InnoDB, remove the InnoDB redo log files (the
ib_logfile* files) from the data directory to avoid
upgrade issues related to redo log file format changes
that may have occurred between releases.
shell> rm ib_logfile*
5. Upgrade the MySQL binaries or packages in place (replace
the old binaries with the new ones).
6. Start the MySQL 5.5 server, using the existing data
directory. For example:
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/existing-datadi
r
7. Run mysql_upgrade. For example:
shell> bin/mysql_upgrade -u root -p password
mysql_upgrade examines all tables in all databases for
incompatibilities with the current version of MySQL.
mysql_upgrade also upgrades the system tables so that you
can take advantage of new privileges or capabilities.
Note
mysql_upgrade does not upgrade the contents of the help
tables. For upgrade instructions, see Section 5.1.10,
"Server-Side Help."
Performing a Logical Upgrade
This section describes how to perform a logical upgrade.
Review Before you Begin before proceeding.
To perform a logical upgrade:
1. Review the changes described in Section 2.11.1.1,
"Changes Affecting Upgrades to 5.5" for steps to be
performed before upgrading.
2. Export your existing data from the previous MySQL
version:
shell> mysqldump --add-drop-table --routines --events --add-drop-table
-> --all-databases --force > data-for-upgrade.sql
Note
Use the --routines and --events options with mysqldump
(as shown above) if your databases include stored
programs. The --all-databases option includes all
databases in the dump, including the mysql database that
holds the system tables.
3. Shut down the old MySQL server. For example:
shell> bin/mysqladmin -u root -p password shutdown
4. Install MySQL 5.5. For installation instructions, see
Chapter 2, "Installing and Upgrading MySQL."
5. Initialize a new data directory:
shell> scripts/mysql_install_db --user=mysql --datadir=/path/to/5.5-da
tadir
6. Start the MySQL 5.5 server, using the new data directory.
For example:
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/5.5-datadir
7. Load the previously created dump file into the new MySQL
server. For example:
shell> bin/mysql -u root -p password --execute="source data-for-upgrad
e.sql" --force
8. Run mysql_upgrade. For example:
shell> bin/mysql_upgrade -u root -p password
mysql_upgrade examines all tables in all databases for
incompatibilities with the current version of MySQL.
mysql_upgrade also upgrades the system tables so that you
can take advantage of new privileges or capabilities.
Note
mysql_upgrade does not upgrade the contents of the help
tables. For upgrade instructions, see Section 5.1.10,
"Server-Side Help."
9. If you use InnoDB, configure MySQL to perform a slow
shutdown by setting innodb_fast_shutdown to 0. For
example:
shell> bin/mysql -u root -p password --execute="set global innodb_fast
_shutdown=0"
10. Shut down and restart the MySQL server to ensure a clean
shutdown and startup. For example:
shell> bin/mysqladmin -u root -p password shutdown
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/5.5-datadir
Upgrade Troubleshooting
* If problems occur, such as that the new mysqld server
does not start or that you cannot connect without a
password, verify that you do not have an old my.cnf file
from your previous installation. You can check this with
the --print-defaults option (for example, mysqld
--print-defaults). If this command displays anything
other than the program name, you have an active my.cnf
file that affects server or client operation.
* If, after an upgrade, you experience problems with
compiled client programs, such as Commands out of sync or
unexpected core dumps, you probably have used old header
or library files when compiling your programs. In this
case, check the date for your mysql.h file and
libmysqlclient.a library to verify that they are from the
new MySQL distribution. If not, recompile your programs
with the new headers and libraries. Recompilation might
also be necessary for programs compiled against the
shared client library if the library major version number
has changed (for example from libmysqlclient.so.15 to
libmysqlclient.so.16.
* If you have created a user-defined function (UDF) with a
given name and upgrade MySQL to a version that implements
a new built-in function with the same name, the UDF
becomes inaccessible. To correct this, use DROP FUNCTION
to drop the UDF, and then use CREATE FUNCTION to
re-create the UDF with a different nonconflicting name.
The same is true if the new version of MySQL implements a
built-in function with the same name as an existing
stored function. See Section 9.2.4, "Function Name
Parsing and Resolution," for the rules describing how the
server interprets references to different kinds of
functions.
2.11.1.1 Changes Affecting Upgrades to 5.5
Before upgrading to MySQL 5.5, review the changes described
in this section to identify upgrade issues that apply to your
current MySQL installation and applications.
Note
In addition to the changes outlined in this section, review
the Release Notes
(http://dev.mysql.com/doc/relnotes/mysql/5.5/en/) and other
important information outlined in Section 2.11.1, "."
Changes marked as either Known issue or Incompatible change
are incompatibilities with earlier versions of MySQL, and may
require your attention before you upgrade. Our aim is to
avoid these changes, but occasionally they are necessary to
correct problems that would be worse than an incompatibility
between releases. If any upgrade issue applicable to your
installation involves an incompatibility that requires
special handling, follow the instructions given in the
incompatibility description. Sometimes this involves dumping
and reloading tables, or use of a statement such as CHECK
TABLE or REPAIR TABLE.
For dump and reload instructions, see Section 2.11.4,
"Rebuilding or Repairing Tables or Indexes." Any procedure
that involves REPAIR TABLE with the USE_FRM option must be
done before upgrading. Use of this statement with a version
of MySQL different from the one used to create the table
(that is, using it after upgrading) may damage the table. See
Section 13.7.2.5, "REPAIR TABLE Syntax."
* Configuration Changes
* Server Changes
* SQL Changes
Configuration Changes
* Incompatible change: The InnoDB Plugin is included in
MySQL 5.5 releases. It becomes the built-in version of
InnoDB in MySQL Server, replacing the version previously
included as the built-in InnoDB engine. InnoDB Plugin is
also available in MySQL 5.1 as of 5.1.38, but it is an
optional storage engine that must be enabled explicitly
using two server options:
[mysqld]
ignore-builtin-innodb
plugin-load=innodb=ha_innodb_plugin.so
If you were using InnoDB Plugin in MySQL 5.1 by means of
those options, you must remove them after an upgrade to
5.5 or the server will fail to start.
In addition, in InnoDB Plugin, the innodb_file_io_threads
system variable has been removed and replaced with
innodb_read_io_threads and innodb_write_io_threads. If
you upgrade from MySQL 5.1 to MySQL 5.5 and previously
explicitly set innodb_file_io_threads at server startup,
you must change your configuration. Either remove any
reference to innodb_file_io_threads or replace it with
references to innodb_read_io_threads and
innodb_write_io_threads.
* Incompatible change: In MySQL 5.5, the server includes a
plugin services interface that complements the plugin
API. The services interface enables server functionality
to be exposed as a "service" that plugins can access
through a function-call interface. The libmysqlservices
library provides access to the available services and
dynamic plugins now must be linked against this library
(use the -lmysqlservices flag). For an example showing
how to configure for CMake, see Section 24.3, "MySQL
Services for Plugins."
Server Changes
* On Linux systems, the libaio library may be needed.
Install it first, if it is not already present on your
system.
* Known issue: As of MySQL 5.5.32, for new installations,
the url columns in the mysql database help tables are now
created as type TEXT to accommodate longer URLs. For
upgrades, mysql_upgrade does not update the columns.
Modify them manually using these statements:
ALTER TABLE mysql.help_category MODIFY url TEXT NOT NULL;
ALTER TABLE mysql.help_topic MODIFY url TEXT NOT NULL;
* Incompatible change: As of MySQL 5.5.3, due to work done
for Bug #989, FLUSH TABLES is not permitted when there is
an active LOCK TABLES ... READ. To provide a workaround
for this restriction, FLUSH TABLES has a new variant,
FLUSH TABLES tbl_list WITH READ LOCK, that enables tables
to be flushed and locked in a single operation. As a
result of this change, applications that previously used
this statement sequence to lock and flush tables will
fail:
LOCK TABLES tbl_list READ;
FLUSH TABLES tbl_list;
Such applications should now use this statement instead:
FLUSH TABLES tbl_list WITH READ LOCK;
* Incompatible change: As of MySQL 5.5.7, the server
requires that a new grant table, proxies_priv, be present
in the mysql database. If you are upgrading to 5.5.7 from
a previous MySQL release rather than performing a new
installation, the server will find that this table is
missing and exit during startup with the following
message:
Table 'mysql.proxies_priv' doesn't exist
To create the proxies_priv table, start the server with
the --skip-grant-tables option to cause it to skip the
normal grant table checks, then run mysql_upgrade. For
example:
shell> mysqld --skip-grant-tables &
shell> mysql_upgrade
Then stop the server and restart it normally.
You can specify other options on the mysqld command line
if necessary. Alternatively, if your installation is
configured so that the server normally reads options from
an option file, use the --defaults-file option to specify
the file (enter each command on a single line):
shell> mysqld --defaults-file=/usr/local/mysql/etc/my.cnf
--skip-grant-tables &
shell> mysql_upgrade
With the --skip-grant-tables option, the server does no
password or privilege checking, so any client can connect
and effectively have all privileges. For additional
security, use the --skip-networking option as well to
prevent remote clients from connecting.
Note
This problem is fixed in MySQL 5.5.8; the server treats a
missing proxies_priv table as equivalent to an empty
table. However, after starting the server, you should
still run mysql_upgrade to create the table.
* Incompatible change: As of MySQL 5.5.7, InnoDB always
uses the fast truncation technique, equivalent to DROP
TABLE and CREATE TABLE. It no longer performs a
row-by-row delete for tables with parent-child foreign
key relationships. TRUNCATE TABLE returns an error for
such tables. Modify your SQL to issue DELETE FROM
table_name for such tables instead.
* Incompatible change: Prior to MySQL 5.5.7, if you flushed
the logs using FLUSH LOGS or mysqladmin flush-logs and
mysqld was writing the error log to a file (for example,
if it was started with the --log-error option), it
renames the current log file with the suffix -old, then
created a new empty log file. This had the problem that a
second log-flushing operation thus caused the original
error log file to be lost unless you saved it under a
different name. For example, you could use the following
commands to save the file:
shell> mysqladmin flush-logs
shell> mv host_name.err-old backup-directory
To avoid the preceding file-loss problem, no renaming
occurs as of MySQL 5.5.7; the server merely closes and
reopens the log file. To rename the file, you can do so
manually before flushing. Then flushing the logs reopens
a new file with the original file name. For example, you
can rename the file and create a new one using the
following commands:
shell> mv host_name.err host_name.err-old
shell> mysqladmin flush-logs
shell> mv host_name.err-old backup-directory
* Incompatible change: As of MySQL 5.5.6, handling of
CREATE TABLE IF NOT EXISTS ... SELECT statements has been
changed for the case that the destination table already
exists:
+ Previously, for CREATE TABLE IF NOT EXISTS ...
SELECT, MySQL produced a warning that the table
exists, but inserted the rows and wrote the
statement to the binary log anyway. By contrast,
CREATE TABLE ... SELECT (without IF NOT EXISTS)
failed with an error, but MySQL inserted no rows and
did not write the statement to the binary log.
+ MySQL now handles both statements the same way when
the destination table exists, in that neither
statement inserts rows or is written to the binary
log. The difference between them is that MySQL
produces a warning when IF NOT EXISTS is present and
an error when it is not.
This change in handling of IF NOT EXISTS results in an
incompatibility for statement-based replication from a
MySQL 5.1 master with the original behavior and a MySQL
5.5 slave with the new behavior. Suppose that CREATE
TABLE IF NOT EXISTS ... SELECT is executed on the master
and the destination table exists. The result is that rows
are inserted on the master but not on the slave.
(Row-based replication does not have this problem.)
To address this issue, statement-based binary logging for
CREATE TABLE IF NOT EXISTS ... SELECT is changed in MySQL
5.1 as of 5.1.51:
+ If the destination table does not exist, there is no
change: The statement is logged as is.
+ If the destination table does exist, the statement
is logged as the equivalent pair of CREATE TABLE IF
NOT EXISTS and INSERT ... SELECT statements. (If the
SELECT in the original statement is preceded by
IGNORE or REPLACE, the INSERT becomes INSERT IGNORE
or REPLACE, respectively.)
This change provides forward compatibility for
statement-based replication from MySQL 5.1 to 5.5 because
when the destination table exists, the rows will be
inserted on both the master and slave. To take advantage
of this compatibility measure, the 5.1 server must be at
least 5.1.51 and the 5.5 server must be at least 5.5.6.
To upgrade an existing 5.1-to-5.5 replication scenario,
upgrade the master first to 5.1.51 or higher. Note that
this differs from the usual replication upgrade advice of
upgrading the slave first.
A workaround for applications that wish to achieve the
original effect (rows inserted regardless of whether the
destination table exists) is to use CREATE TABLE IF NOT
EXISTS and INSERT ... SELECT statements rather than
CREATE TABLE IF NOT EXISTS ... SELECT statements.
Along with the change just described, the following
related change was made: Previously, if an existing view
was named as the destination table for CREATE TABLE IF
NOT EXISTS ... SELECT, rows were inserted into the
underlying base table and the statement was written to
the binary log. As of MySQL 5.1.51 and 5.5.6, nothing is
inserted or logged.
* Incompatible change: Prior to MySQL 5.5.6, if the server
was started with character_set_server set to utf16, it
crashed during full-text stopword initialization. Now the
stopword file is loaded and searched using latin1 if
character_set_server is ucs2, utf16, or utf32. If any
table was created with FULLTEXT indexes while the server
character set was ucs2, utf16, or utf32, it should be
repaired using this statement:
REPAIR TABLE tbl_name QUICK;
* Incompatible change: As of MySQL 5.5.5, all numeric
operators and functions on integer, floating-point and
DECIMAL values throw an "out of range" error
(ER_DATA_OUT_OF_RANGE) rather than returning an incorrect
value or NULL, when the result is out of the supported
range for the corresponding data type. See Section
11.2.6, "Out-of-Range and Overflow Handling."
* Incompatible change: In very old versions of MySQL (prior
to 4.1), the TIMESTAMP data type supported a display
width, which was silently ignored beginning with MySQL
4.1. This is deprecated in MySQL 5.1, and removed
altogether in MySQL 5.5. These changes in behavior can
lead to two problem scenarios when trying to use
TIMESTAMP(N) columns with a MySQL 5.5 or later server:
+ When importing a dump file (for example, one created
using mysqldump) created in a MySQL 5.0 or earlier
server into a server from a newer release series, a
CREATE TABLE or ALTER TABLE statement containing
TIMESTAMP(N) causes the import to fail with a syntax
error.
To fix this problem, edit the dump file in a text
editor to replace any instances of TIMESTAMP(N) with
TIMESTAMP prior to importing the file. Be sure to
use a plain text editor for this, and not a word
processor; otherwise, the result is almost certain
to be unusable for importing into the MySQL server.
+ When trying replicate any CREATE TABLE or ALTER
TABLE statement containing TIMESTAMP(N) from a
master MySQL server that supports the TIMESTAMP(N)
syntax to a MySQL 5.5.3 or newer slave, the
statement causes replication to fail. Similarly,
when you try to restore from a binary log written by
a server that supports TIMESTAMP(N) to a MySQL 5.5.3
or newer server, any CREATE TABLE or ALTER TABLE
statement containing TIMESTAMP(N) causes the backup
to fail. This holds true regardless of the logging
format.
It may be possible to fix such issues using a hex
editor, by replacing any width arguments used with
TIMESTAMP, and the parentheses containing them, with
space characters (hexadecimal 20). Be sure to use a
programmer's binary hex editor and not a regular
text editor or word processor for this; otherwise,
the result is almost certain to be a corrupted
binary log file. To guard against accidental
corruption of the binary log, you should always work
on a copy of the file rather than the original.
You should try to handle potential issues of these types
proactively by updating with ALTER TABLE any TIMESTAMP(N)
columns in your databases so that they use TIMESTAMP
instead, before performing any upgrades.
* Incompatible change: As of MySQL 5.5.3, the Unicode
implementation has been extended to provide support for
supplementary characters that lie outside the Basic
Multilingual Plane (BMP). Noteworthy features:
+ utf16 and utf32 character sets have been added.
These correspond to the UTF-16 and UTF-32 encodings
of the Unicode character set, and they both support
supplementary characters.
+ The utf8mb4 character set has been added. This is
similar to utf8, but its encoding allows up to four
bytes per character to enable support for
supplementary characters.
+ The ucs2 character set is essentially unchanged
except for the inclusion of some newer BMP
characters.
In most respects, upgrading to MySQL 5.5 should present
few problems with regard to Unicode usage, although there
are some potential areas of incompatibility. These are
the primary areas of concern:
+ For the variable-length character data types
(VARCHAR and the TEXT types), the maximum length in
characters is less for utf8mb4 columns than for utf8
columns.
+ For all character data types (CHAR, VARCHAR, and the
TEXT types), the maximum number of characters that
can be indexed is less for utf8mb4 columns than for
utf8 columns.
Consequently, if you want to upgrade tables from utf8 to
utf8mb4 to take advantage of supplementary-character
support, it may be necessary to change some column or
index definitions.
For additional details about the new Unicode character
sets and potential incompatibilities, see Section
10.1.10, "Unicode Support," and Section 10.1.11,
"Upgrading from Previous to Current Unicode Support."
* Incompatible change: As of MySQL 5.5.3, the server
includes dtoa, a library for conversion between strings
and numbers by David M. Gay. In MySQL, this library
provides the basis for improved conversion between string
or DECIMAL values and approximate-value (FLOAT or DOUBLE)
numbers.
Because the conversions produced by this library differ
in some cases from previous results, the potential exists
for incompatibilities in applications that rely on
previous results. For example, applications that depend
on a specific exact result from previous conversions
might need adjustment to accommodate additional
precision.
For additional information about the properties of dtoa
conversions, see Section 12.2, "Type Conversion in
Expression Evaluation."
* Incompatible change: In MySQL 5.5, several changes were
made regarding the language and character set of error
messages:
+ The --language option for specifying the directory
for the error message file is now deprecated. The
new lc_messages_dir and lc_messages system variables
should be used instead, and the server treats
--language as an alias for lc_messages_dir.
+ The language system variable has been removed and
replaced with the new lc_messages_dir and
lc_messages system variables. lc_messages_dir has
only a global value and is read only. lc_messages
has global and session values and can be modified at
runtime, so the error message language can be
changed while the server is running, and individual
clients each can have a different error message
language by changing their session lc_messages value
to a different locale name.
+ Error messages previously were constructed in a mix
of character sets. This issue is resolved by
constructing error messages internally within the
server using UTF-8 and returning them to the client
in the character set specified by the
character_set_results system variable. The content
of error messages therefore may in some cases differ
from the messages returned previously.
For more information, see Section 10.2, "Setting the
Error Message Language," and Section 10.1.6, "Character
Set for Error Messages."
* Incompatible change: MySQL 5.5 implements new functions
used to calculate row placement for tables partitioned by
KEY and LINEAR KEY. Tables that were created using KEY or
LINEAR KEY partitioning in MySQL 5.1 can be upgraded in
MySQL 5.5.31 and later using ALTER TABLE ... PARTITION BY
ALGORITHM=2 [LINEAR] KEY (...). (Bug #14521864, Bug
#66462)
SQL Changes
* Incompatible change: Previously, the parser accepted an
INTO clause in nested SELECT statements, which is invalid
because such statements must return their results to the
outer context. As of MySQL 5.5.3, this syntax is no
longer permitted and statements that use it must be
changed.
* Incompatible change: In MySQL 5.5.3, several changes were
made to alias resolution in multiple-table DELETE
statements so that it is no longer possible to have
inconsistent or ambiguous table aliases.
+ In MySQL 5.1.23, alias declarations outside the
table_references part of the statement were
disallowed for the USING variant of multiple-table
DELETE syntax, to reduce the possibility of
ambiguous aliases that could lead to ambiguous
statements that have unexpected results such as
deleting rows from the wrong table.
As of MySQL 5.5.3, alias declarations outside
table_references are disallowed for all
multiple-table DELETE statements. Alias declarations
are permitted only in the table_references part.
Incorrect:
DELETE FROM t1 AS a2 USING t1 AS a1 INNER JOIN t2 AS a2;
DELETE t1 AS a2 FROM t1 AS a1 INNER JOIN t2 AS a2;
Correct:
DELETE FROM t1 USING t1 AS a1 INNER JOIN t2 AS a2;
DELETE t1 FROM t1 AS a1 INNER JOIN t2 AS a2;
+ Previously, for alias references in the list of
tables from which to delete rows in a multiple-table
delete, the default database is used unless one is
specified explicitly. For example, if the default
database is db1, the following statement does not
work because the unqualified alias reference a2 is
interpreted as having a database of db1:
DELETE a1, a2 FROM db1.t1 AS a1 INNER JOIN db2.t2 AS a2
WHERE a1.id=a2.id;
To correctly match an alias that refers to a table
outside the default database, you must explicitly
qualify the reference with the name of the proper
database:
DELETE a1, db2.a2 FROM db1.t1 AS a1 INNER JOIN db2.t2 AS a2
WHERE a1.id=a2.id;
As of MySQL 5.5.3, alias resolution does not require
qualification and alias references should not be
qualified with the database name. Qualified names
are interpreted as referring to tables, not aliases.
Statements containing alias constructs that are no longer
permitted must be rewritten.
* Some keywords may be reserved in MySQL 5.5 that were not
reserved in MySQL 5.1. See Section 9.3, "Keywords and
Reserved Words."
2.11.2 Downgrading MySQL
This section describes how to downgrade to an older MySQL
version.
* Supported Downgrade Methods
* Supported Downgrade Paths
* Before You Begin
* Performing an In-place Downgrade
* Performing a Logical Downgrade
* Downgrade Troubleshooting
Supported Downgrade Methods
Supported downgrade methods include:
* In-place Downgrade: Involves shutting down the new MySQL
version, replacing the new MySQL binaries or packages
with the old ones, and restarting the old MySQL version
on the new data files. In-place downgrades are supported
for downgrades between GA versions within the same
release series. For example, in-place downgrades are
supported for downgrades from 5.5.46 to 5.5.45.
* Logical Downgrade: Involves using mysqldump to dump all
tables from the new MySQL version, and then loading the
dump file into the old MySQL version. Logical downgrades
are supported for downgrades between GA versions within
the same release series and for downgrades between
release levels. For example, logical downgrades are
supported for downgrades from 5.5.46 to 5.5.45 and for
downgrades from 5.5 to 5.1.
Supported Downgrade Paths
Unless otherwise documented, the following downgrade paths
are supported:
* Downgrading from a release series version to an older
release series version is supported using all downgrade
methods. For example, downgrading from 5.546 to 5.5.45 is
supported. Skipping release series versions is also
supported. For example, downgrading from 5.5.46 to 5.5.44
is supported.
* Downgrading one release level is supported using the
logical downgrade method. For example, downgrading from
5.5 to 5.1 is supported.
* Downgrading more than one release level is supported
using the logical downgrade method, but only if you
downgrade one release level at a time. For example, you
can downgrade from 5.5 to 5.1, and then to 5.0.
The following conditions apply to all downgrade paths:
* Downgrades between General Availability (GA) status
releases are supported.
* Downgrades between milestone releases (or from a GA
release to a milestone release) are not supported. For
example, downgrading from MySQL 5.5.8 to MySQL 5.5.7 is
not supported, as 5.5.7 is not a GA status release.
Before You Begin
Before downgrading, the following steps are recommended:
* Review the Release Notes
(http://dev.mysql.com/doc/relnotes/mysql/5.5/en/) for the
MySQL version you are downgrading from to ensure that
there are no features or fixes that you really need.
* Review Section 2.11.2.1, "Changes Affecting Downgrades
from MySQL 5.5." This section describes changes that may
require action before or after downgrading.
Note
The downgrade procedures described in the following
sections assume you are downgrading with data files
created or modified by the newer MySQL version. However,
if you did not modify your data after upgrading,
downgrading using backups taken before upgrading to the
new MySQL version is recommended. Many of the changes
described in Section 2.11.2.1, "Changes Affecting
Downgrades from MySQL 5.5" that require action before or
after downgrading are not applicable when downgrading
using backups taken before upgrading to the new MySQL
version.
* Always back up your current databases and log files
before downgrading. The backup should include the mysql
database, which contains the MySQL system tables. See
Section 7.2, "Database Backup Methods."
* Use of new features, new configuration options, or new
configuration option values that are not supported by a
previous release may cause downgrade errors or failures.
Before downgrading, it is recommended that you reverse
changes resulting from the use of new features and remove
configuration settings that are not supported by the
release you are downgrading to.
* Check Section 2.11.3, "Checking Whether Tables or Indexes
Must Be Rebuilt," to see whether changes to table formats
or to character sets or collations were made between your
current version of MySQL and the version to which you are
downgrading. If such changes have resulted in an
incompatibility between MySQL versions, downgrade the
affected tables using the instructions in Section 2.11.4,
"Rebuilding or Repairing Tables or Indexes."
* If you use XA transactions with InnoDB, run XA RECOVER
before downgrading to check for uncommitted XA
transactions. If results are returned, either commit or
rollback the XA transactions by issuing an XA COMMIT or
XA ROLLBACK statement.
Performing an In-place Downgrade
In-place downgrades are supported for downgrades between GA
status releases within the same release series. Review Before
you Begin before proceeding.
To perform an in-place downgrade:
1. Review the changes described in Section 2.11.2.1,
"Changes Affecting Downgrades from MySQL 5.5" for steps
to be performed before downgrading.
2. If you use InnoDB, configure MySQL to perform a slow
shutdown by setting innodb_fast_shutdown to 0. For
example:
shell> bin/mysql -u root -p password --execute="set global innodb_fast
_shutdown=0"
With a slow shutdown, InnoDB performs a full purge and
change buffer merge before shutting down, which ensures
that data files are fully prepared in case of file format
differences between releases.
3. Shut down the newer MySQL server. For example:
shell> bin/mysqladmin -u root -p password shutdown
4. After the slow shutdown, remove the InnoDB redo log files
(the ib_logfile* files) from the data directory to avoid
downgrade issues related to redo log file format changes
that may have occurred between releases.
shell> rm ib_logfile*
5. Downgrade the MySQL binaries or packages in-place by
replacing the newer binaries or packages with the older
ones.
6. Start the older (downgraded) MySQL server, using the
existing data directory. For example:
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/existing-datadi
r
7. Run mysql_upgrade. For example:
shell> bin/mysql_upgrade -u root -p password
Performing a Logical Downgrade
Logical downgrades are supported for downgrades between
releases within the same release series and for downgrades to
the previous release level. Only downgrades between General
Availability (GA) status releases are supported. Review
Before you Begin before proceeding.
To perform a logical downgrade:
1. Review the changes described in Section 2.11.2.1,
"Changes Affecting Downgrades from MySQL 5.5" for steps
to be performed before downgrading.
2. Dump all databases. For example:
shell> bin/mysqldump --add-drop-table --events -u root -p password --a
ll-databases --force > all_5_5_databases_dump.sql
3. Shut down the newer MySQL server. For example:
shell> bin/mysqladmin -u root -p password shutdown
4. Initialize an older MySQL instance, with a new data
directory. For example:
shell> scripts/mysql_install_db --user=mysql
5. Start the older MySQL server, using the new data
directory. For example:
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/new-datadir
6. Load the dump file into the older MySQL server. For
example:
shell> bin/mysql -u root -p password --execute="source all_5_5_databas
es_dump.sql" --force
7. Run mysql_upgrade. For example:
shell> bin/mysql_upgrade -u root -p password
8. If you use InnoDB, configure MySQL to perform a slow
shutdown by setting innodb_fast_shutdown to 0. For
example:
shell> bin/mysql -u root -p password --execute="set global innodb_fast
_shutdown=0"
9. Shut down and restart the MySQL server to ensure a clean
shutdown and startup. For example:
shell> bin/mysqladmin -u root -p password shutdown
shell> bin/mysqld_safe --user=mysql --datadir=/path/to/new-datadir
Downgrade Troubleshooting
If you downgrade from one release series to another, there
may be incompatibilities in table storage formats. In this
case, use mysqldump to dump your tables before downgrading.
After downgrading, reload the dump file using mysql or
mysqlimport to re-create your tables. For examples, see
Section 2.11.5, "Copying MySQL Databases to Another Machine."
A typical symptom of a downward-incompatible table format
change when you downgrade is that you cannot open tables. In
that case, use the following procedure:
1. Stop the older MySQL server that you are downgrading to.
2. Restart the newer MySQL server you are downgrading from.
3. Dump any tables that were inaccessible to the older
server by using mysqldump to create a dump file.
4. Stop the newer MySQL server and restart the older one.
5. Reload the dump file into the older server. Your tables
should be accessible.
2.11.2.1 Changes Affecting Downgrades from MySQL 5.5
Before downgrading from MySQL 5.5, review the changes
described in this section. Some changes may require action
before or after downgrading.
* System Tables. The mysql.proc.comment column definition
changed between MySQL 5.1 and 5.5. After downgrading from
5.5 to 5.1, this table is seen as corrupt and in need of
repair. Running mysql_upgrade from the version of MySQL
to which you downgraded (as documented in the downgrade
procedures) reverts the mysql.proc.comment column
definition.
* InnoDB. MySQL 5.5 uses InnoDB Plugin as the built-in
version of InnoDB. MySQL 5.1 includes InnoDB Plugin as of
5.1.38, but as an option that must be enabled explicitly.
See the Release Notes
(http://dev.mysql.com/doc/relnotes/mysql/5.5/en/) for
MySQL 5.1.38.
* Tables partitioned by [LINEAR] KEY. MySQL 5.5 implements
new functions used to calculate row placement for tables
partitioned by KEY and LINEAR KEY. Tables that were
created using KEY or LINEAR KEY partitioning in MySQL 5.5
cannot be used by a MySQL 5.1 server. In MySQL 5.5.31 and
later, you can downgrade such tables with ALTER TABLE ...
PARTITION BY ALGORITHM=1 [LINEAR] KEY (...) to make them
compatible with MySQL 5.1.
2.11.2.2 Downgrading from MySQL Enterprise Edition to MySQL
Community Server
This section describes the steps required to downgrade from
MySQL Enterprise Edition to MySQL Community Edition. This can
be done at any time, and is required at the expiration of a
MySQL Enterprise Edition subscription if you wish to continue
using MySQL Server.
When you perform such a downgrade, all commercially licensed
components of the MySQL Enterprise Edition subscription must
be uninstalled. These components and related considerations
are described in the rest of this section.
Note
The issues described in this section are in addition to any
that may be encountered as a result of any upgrade or
downgrade of the MySQL Server version (such as between MySQL
5.5 and 5.1). Information about upgrading and downgrading
between MySQL release series can be found elsewhere in this
chapter; see Section 2.11.1, "Upgrading MySQL," and Section
2.11.2, "Downgrading MySQL."
MySQL Enterprise Database Server. All commercial versions of
MySQL Database Server must be uninstalled.
Commercially licensed extensions. All commercially licensed
MySQL Enterprise Database Server extensions must be
uninstalled. This includes the following commercial
extensions:
* MySQL External Authentication for Windows: Following
uninstallation of this plugin, existing MySQL user
accounts must be re-created using local authentication.
See Section 6.3, "MySQL User Account Management," for
more information.
* MySQL External Authentication for PAM: Following
uninstallation of this plugin, existing MySQL user
accounts must be re-created using local authentication.
See Section 6.3, "MySQL User Account Management," for
more information.
* MySQL Enterprise Thread Pool: Following uninstallation of
this plugin, existing MySQL servers revert to default
thread and connection handling.
* MySQL Enterprise Audit: Following uninstallation of this
plugin, no logging of user logins or query activity
occurs.
* MySQL High Availability: Following uninstallation of this
plugin, automated failover is no longer available.
MySQL Enterprise Backup. MySQL Enterprise Backup must be
uninstalled. Uninstalling this application has the effects
listed here:
* Automated backup scripts no longer work.
* Existing backup images taken with MySQL Enterprise Backup
can no longer be used for recovery.
* Third-party integration with multimedia systems such as
NetBackup, Tivoli, and Oracle Secure Backup no longer
works.
MySQL Enterprise Monitor, MySQL Query Analyzer, agents.
MySQL Enterprise Monitor, MySQL Query Analyzer, and all
server-side agents must be uninstalled. Uninstalling these
applications and agents has the following effects:
* Automated SNMP and SMTP alerts no longer work.
* All historical MySQL, OS monitoring, query, and
performance metrics as well as all trending data are
lost.
* All environment-specific monitoring templates, custom
advisors, graphs and scripts are also lost.
2.11.3 Checking Whether Tables or Indexes Must Be Rebuilt
A binary upgrade or downgrade is one that installs one
version of MySQL "in place" over an existing version, without
dumping and reloading tables:
1. Stop the server for the existing version if it is
running.
2. Install a different version of MySQL. This is an upgrade
if the new version is higher than the original version, a
downgrade if the version is lower.
3. Start the server for the new version.
In many cases, the tables from the previous version of MySQL
can be used without problem by the new version. However,
sometimes changes occur that require tables or table indexes
to be rebuilt, as described in this section. If you have
tables that are affected by any of the issues described here,
rebuild the tables or indexes as necessary using the
instructions given in Section 2.11.4, "Rebuilding or
Repairing Tables or Indexes."
Table Incompatibilities
After a binary upgrade to MySQL 5.1 from a MySQL 5.0
installation that contains ARCHIVE tables, accessing those
tables causes the server to crash, even if you have run
mysql_upgrade or CHECK TABLE ... FOR UPGRADE. To work around
this problem, use mysqldump to dump all ARCHIVE tables before
upgrading, and reload them into MySQL 5.1 after upgrading.
The same problem occurs for binary downgrades from MySQL 5.1
to 5.0.
The upgrade problem is fixed in MySQL 5.6.4: The server can
open ARCHIVE tables created in MySQL 5.0. However, it remains
the recommended upgrade procedure to dump 5.0 ARCHIVE tables
before upgrading and reload them after upgrading.
Index Incompatibilities
In MySQL 5.6.3, the length limit for index prefix keys is
increased from 767 bytes to 3072 bytes, for InnoDB tables
using ROW_FORMAT=DYNAMIC or ROW_FORMAT=COMPRESSED. See
Section 14.8.7, "Limits on InnoDB Tables" for details. This
change is also backported to MySQL 5.5.14. If you downgrade
from one of these releases or higher, to an earlier release
with a lower length limit, the index prefix keys could be
truncated at 767 bytes or the downgrade could fail. This
issue could only occur if the configuration option
innodb_large_prefix was enabled on the server being
downgraded.
If you perform a binary upgrade without dumping and reloading
tables, you cannot upgrade directly from MySQL 4.1 to 5.1 or
higher. This occurs due to an incompatible change in the
MyISAM table index format in MySQL 5.0. Upgrade from MySQL
4.1 to 5.0 and repair all MyISAM tables. Then upgrade from
MySQL 5.0 to 5.1 and check and repair your tables.
Modifications to the handling of character sets or collations
might change the character sort order, which causes the
ordering of entries in any index that uses an affected
character set or collation to be incorrect. Such changes
result in several possible problems:
* Comparison results that differ from previous results
* Inability to find some index values due to misordered
index entries
* Misordered ORDER BY results
* Tables that CHECK TABLE reports as being in need of
repair
The solution to these problems is to rebuild any indexes that
use an affected character set or collation, either by
dropping and re-creating the indexes, or by dumping and
reloading the entire table. In some cases, it is possible to
alter affected columns to use a different collation. For
information about rebuilding indexes, see Section 2.11.4,
"Rebuilding or Repairing Tables or Indexes."
To check whether a table has indexes that must be rebuilt,
consult the following list. It indicates which versions of
MySQL introduced character set or collation changes that
require indexes to be rebuilt. Each entry indicates the
version in which the change occurred and the character sets
or collations that the change affects. If the change is
associated with a particular bug report, the bug number is
given.
The list applies both for binary upgrades and downgrades. For
example, Bug #27877 was fixed in MySQL 5.1.24, so it applies
to upgrades from versions older than 5.1.24 to 5.1.24 or
newer, and to downgrades from 5.1.24 or newer to versions
older than 5.1.24.
In many cases, you can use CHECK TABLE ... FOR UPGRADE to
identify tables for which index rebuilding is required. It
will report this message:
Table upgrade required.
Please do "REPAIR TABLE `tbl_name`" or dump/reload to fix it!
In these cases, you can also use mysqlcheck --check-upgrade
or mysql_upgrade, which execute CHECK TABLE. However, the use
of CHECK TABLE applies only after upgrades, not downgrades.
Also, CHECK TABLE is not applicable to all storage engines.
For details about which storage engines CHECK TABLE supports,
see Section 13.7.2.2, "CHECK TABLE Syntax."
These changes cause index rebuilding to be necessary:
* MySQL 5.1.24 (Bug #27877)
Affects indexes that use the utf8_general_ci or
ucs2_general_ci collation for columns that contain 'ß'
LATIN SMALL LETTER SHARP S (German). The bug fix
corrected an error in the original collations but
introduced an incompatibility such that 'ß' compares
equal to characters with which it previously compared
different.
Affected tables can be detected by CHECK TABLE ... FOR
UPGRADE as of MySQL 5.1.30 (see Bug #40053).
A workaround for this issue is implemented as of MySQL
5.1.62, 5.5.21, and 5.6.5. The workaround involves
altering affected columns to use the
utf8_general_mysql500_ci and ucs2_general_mysql500_ci
collations, which preserve the original pre-5.1.24
ordering of utf8_general_ci and ucs2_general_ci.
* MySQL 5.0.48, 5.1.23 (Bug #27562)
Affects indexes that use the ascii_general_ci collation
for columns that contain any of these characters: '`'
GRAVE ACCENT, '[' LEFT SQUARE BRACKET, '\' REVERSE
SOLIDUS, ']' RIGHT SQUARE BRACKET, '~' TILDE
Affected tables can be detected by CHECK TABLE ... FOR
UPGRADE as of MySQL 5.1.29 (see Bug #39585).
* MySQL 5.0.48, 5.1.21 (Bug #29461)
Affects indexes for columns that use any of these
character sets: eucjpms, euc_kr, gb2312, latin7, macce,
ujis
Affected tables can be detected by CHECK TABLE ... FOR
UPGRADE as of MySQL 5.1.29 (see Bug #39585).
2.11.4 Rebuilding or Repairing Tables or Indexes
This section describes how to rebuild a table. This can be
necessitated by changes to MySQL such as how data types are
handled or changes to character set handling. For example, an
error in a collation might have been corrected, necessitating
a table rebuild to update the indexes for character columns
that use the collation. (For examples, see Section 2.11.3,
"Checking Whether Tables or Indexes Must Be Rebuilt.") It
might also be that a table repair or upgrade should be done
as indicated by a table check operation such as that
performed by CHECK TABLE, mysqlcheck, or mysql_upgrade.
Methods for rebuilding a table include dumping and reloading
it, or using ALTER TABLE or REPAIR TABLE. REPAIR TABLE only
applies to MyISAM, ARCHIVE, and CSV tables.
Note
If you are rebuilding tables because a different version of
MySQL will not handle them after a binary (in-place) upgrade
or downgrade, you must use the dump-and-reload method. Dump
the tables before upgrading or downgrading using your
original version of MySQL. Then reload the tables after
upgrading or downgrading.
If you use the dump-and-reload method of rebuilding tables
only for the purpose of rebuilding indexes, you can perform
the dump either before or after upgrading or downgrading.
Reloading still must be done afterward.
To rebuild a table by dumping and reloading it, use mysqldump
to create a dump file and mysql to reload the file:
shell> mysqldump db_name t1 > dump.sql
shell> mysql db_name < dump.sql
To rebuild all the tables in a single database, specify the
database name without any following table name:
shell> mysqldump db_name > dump.sql
shell> mysql db_name < dump.sql
To rebuild all tables in all databases, use the
--all-databases option:
shell> mysqldump --all-databases > dump.sql
shell> mysql < dump.sql
To rebuild a table with ALTER TABLE, use a "null" alteration;
that is, an ALTER TABLE statement that "changes" the table to
use the storage engine that it already has. For example, if
t1 is an InnoDB table, use this statement:
mysql> ALTER TABLE t1 ENGINE = InnoDB;
If you are not sure which storage engine to specify in the
ALTER TABLE statement, use SHOW CREATE TABLE to display the
table definition.
If you need to rebuild an InnoDB table because a CHECK TABLE
operation indicates that a table upgrade is required, use
mysqldump to create a dump file and mysql to reload the file,
as described earlier. If the CHECK TABLE operation indicates
that there is a corruption or causes InnoDB to fail, refer to
Section 14.20.2, "Forcing InnoDB Recovery" for information
about using the innodb_force_recovery option to restart
InnoDB. To understand the type of problem that CHECK TABLE
may be encountering, refer to the InnoDB notes in Section
13.7.2.2, "CHECK TABLE Syntax."
For MyISAM, ARCHIVE, or CSV tables, you can use REPAIR TABLE
if the table checking operation indicates that there is a
corruption or that an upgrade is required. For example, to
repair a MyISAM table, use this statement:
mysql> REPAIR TABLE t1;
mysqlcheck --repair provides command-line access to the
REPAIR TABLE statement. This can be a more convenient means
of repairing tables because you can use the --databases or
--all-databases option to repair all tables in specific
databases or all databases, respectively:
shell> mysqlcheck --repair --databases db_name ...
shell> mysqlcheck --repair --all-databases
For incompatibilities introduced in MySQL 5.1.24 by the fix
for Bug #27877 that corrected the utf8_general_ci and
ucs2_general_ci collations, a workaround is implemented as of
MySQL 5.1.62, 5.5.21, and 5.6.5. Upgrade to one of those
versions, then convert each affected table using one of the
following methods. In each case, the workaround altering
affected columns to use the utf8_general_mysql500_ci and
ucs2_general_mysql500_ci collations, which preserve the
original pre-5.1.24 ordering of utf8_general_ci and
ucs2_general_ci.
* To convert an affected table after a binary upgrade that
leaves the table files in place, alter the table to use
the new collation. Suppose that the table t1 contains one
or more problematic utf8 columns. To convert the table at
the table level, use a statement like this:
ALTER TABLE t1
CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_mysql500_ci;
To apply the change on a column-specific basis, use a
statement like this (be sure to repeat the column
definition as originally specified except for the COLLATE
clause):
ALTER TABLE t1
MODIFY c1 CHAR(N) CHARACTER SET utf8 COLLATE utf8_general_mysql500_ci;
* To upgrade the table using a dump and reload procedure,
dump the table using mysqldump, modify the CREATE TABLE
statement in the dump file to use the new collation, and
reload the table.
After making the appropriate changes, CHECK TABLE should
report no error.
2.11.5 Copying MySQL Databases to Another Machine
In cases where you need to transfer databases between
different architectures, you can use mysqldump to create a
file containing SQL statements. You can then transfer the
file to the other machine and feed it as input to the mysql
client.
Note
You can copy the .frm, .MYI, and .MYD files for MyISAM tables
between different architectures that support the same
floating-point format. (MySQL takes care of any byte-swapping
issues.) See Section 15.3, "The MyISAM Storage Engine."
Use mysqldump --help to see what options are available.
The easiest (although not the fastest) way to move a database
between two machines is to run the following commands on the
machine on which the database is located:
shell> mysqladmin -h 'other_hostname' create db_name
shell> mysqldump db_name | mysql -h 'other_hostname' db_name
If you want to copy a database from a remote machine over a
slow network, you can use these commands:
shell> mysqladmin create db_name
shell> mysqldump -h 'other_hostname' --compress db_name | mysql db_nam
e
You can also store the dump in a file, transfer the file to
the target machine, and then load the file into the database
there. For example, you can dump a database to a compressed
file on the source machine like this:
shell> mysqldump --quick db_name | gzip > db_name.gz
Transfer the file containing the database contents to the
target machine and run these commands there:
shell> mysqladmin create db_name
shell> gunzip < db_name.gz | mysql db_name
You can also use mysqldump and mysqlimport to transfer the
database. For large tables, this is much faster than simply
using mysqldump. In the following commands, DUMPDIR
represents the full path name of the directory you use to
store the output from mysqldump.
First, create the directory for the output files and dump the
database:
shell> mkdir DUMPDIR
shell> mysqldump --tab=DUMPDIR db_name
Then transfer the files in the DUMPDIR directory to some
corresponding directory on the target machine and load the
files into MySQL there:
shell> mysqladmin create db_name # create database
shell> cat DUMPDIR/*.sql | mysql db_name # create tables in database
shell> mysqlimport db_name DUMPDIR/*.txt # load data into tables
Do not forget to copy the mysql database because that is
where the grant tables are stored. You might have to run
commands as the MySQL root user on the new machine until you
have the mysql database in place.
After you import the mysql database on the new machine,
execute mysqladmin flush-privileges so that the server
reloads the grant table information.
2.12 Environment Variables
This section lists all the environment variables that are
used directly or indirectly by MySQL. Most of these can also
be found in other places in this manual.
Options on the command line take precedence over values
specified in option files and environment variables, and
values in option files take precedence over values in
environment variables.
In many cases, it is preferable to use an option file instead
of environment variables to modify the behavior of MySQL. See
Section 4.2.6, "Using Option Files."
Variable Description
CXX The name of your C++ compiler (for running CMake).
CC The name of your C compiler (for running CMake).
DBI_USER The default user name for Perl DBI.
DBI_TRACE Trace options for Perl DBI.
HOME The default path for the mysql history file is
$HOME/.mysql_history.
LD_RUN_PATH Used to specify the location of
libmysqlclient.so.
LIBMYSQL_ENABLE_CLEARTEXT_PLUGIN Enable mysql_clear_password
authentication plugin; see Section 6.3.7.5, "The Cleartext
Client-Side Authentication Plugin."
MYSQL_DEBUG Debug trace options when debugging.
MYSQL_GROUP_SUFFIX Option group suffix value (like specifying
--defaults-group-suffix).
MYSQL_HISTFILE The path to the mysql history file. If this
variable is set, its value overrides the default for
$HOME/.mysql_history.
MYSQL_HOME The path to the directory in which the
server-specific my.cnf file resides.
MYSQL_HOST The default host name used by the mysql
command-line client.
MYSQL_PS1 The command prompt to use in the mysql command-line
client.
MYSQL_PWD The default password when connecting to mysqld.
Note that using this is insecure. See Section 6.1.2.1,
"End-User Guidelines for Password Security."
MYSQL_TCP_PORT The default TCP/IP port number.
MYSQL_UNIX_PORT The default Unix socket file name; used for
connections to localhost.
PATH Used by the shell to find MySQL programs.
TMPDIR The directory where temporary files are created.
TZ This should be set to your local time zone. See Section
B.5.4.6, "Time Zone Problems."
UMASK The user-file creation mode when creating files. See
note following table.
UMASK_DIR The user-directory creation mode when creating
directories. See note following table.
USER The default user name on Windows when connecting to
mysqld.
For information about the mysql history file, see Section
4.5.1.3, "mysql Logging."
The UMASK and UMASK_DIR variables, despite their names, are
used as modes, not masks:
* If UMASK is set, mysqld uses ($UMASK | 0600) as the mode
for file creation, so that newly created files have a
mode in the range from 0600 to 0666 (all values octal).
* If UMASK_DIR is set, mysqld uses ($UMASK_DIR | 0700) as
the base mode for directory creation, which then is
AND-ed with ~(~$UMASK & 0666), so that newly created
directories have a mode in the range from 0700 to 0777
(all values octal). The AND operation may remove read and
write permissions from the directory mode, but not
execute permissions.
MySQL assumes that the value for UMASK or UMASK_DIR is in
octal if it starts with a zero.
2.13 Perl Installation Notes
The Perl DBI module provides a generic interface for database
access. You can write a DBI script that works with many
different database engines without change. To use DBI, you
must install the DBI module, as well as a DataBase Driver
(DBD) module for each type of database server you want to
access. For MySQL, this driver is the DBD::mysql module.
Perl, and the DBD::MySQL module for DBI must be installed if
you want to run the MySQL benchmark scripts; see Section
8.13.2, "The MySQL Benchmark Suite." They are also required
for the MySQL Cluster ndb_size.pl utility; see Section
18.4.24, "ndb_size.pl --- NDBCLUSTER Size Requirement
Estimator."
Note
Perl support is not included with MySQL distributions. You
can obtain the necessary modules from http://search.cpan.org
for Unix, or by using the ActiveState ppm program on Windows.
The following sections describe how to do this.
The DBI/DBD interface requires Perl 5.6.0, and 5.6.1 or later
is preferred. DBI does not work if you have an older version
of Perl. You should use DBD::mysql 4.009 or higher. Although
earlier versions are available, they do not support the full
functionality of MySQL 5.5.
2.13.1 Installing Perl on Unix
MySQL Perl support requires that you have installed MySQL
client programming support (libraries and header files). Most
installation methods install the necessary files. If you
install MySQL from RPM files on Linux, be sure to install the
developer RPM as well. The client programs are in the client
RPM, but client programming support is in the developer RPM.
The files you need for Perl support can be obtained from the
CPAN (Comprehensive Perl Archive Network) at
http://search.cpan.org.
The easiest way to install Perl modules on Unix is to use the
CPAN module. For example:
shell> perl -MCPAN -e shell
cpan> install DBI
cpan> install DBD::mysql
The DBD::mysql installation runs a number of tests. These
tests attempt to connect to the local MySQL server using the
default user name and password. (The default user name is
your login name on Unix, and ODBC on Windows. The default
password is "no password.") If you cannot connect to the
server with those values (for example, if your account has a
password), the tests fail. You can use force install
DBD::mysql to ignore the failed tests.
DBI requires the Data::Dumper module. It may be installed; if
not, you should install it before installing DBI.
It is also possible to download the module distributions in
the form of compressed tar archives and build the modules
manually. For example, to unpack and build a DBI
distribution, use a procedure such as this:
1. Unpack the distribution into the current directory:
shell> gunzip < DBI-VERSION.tar.gz | tar xvf -
This command creates a directory named DBI-VERSION.
2. Change location into the top-level directory of the
unpacked distribution:
shell> cd DBI-VERSION
3. Build the distribution and compile everything:
shell> perl Makefile.PL
shell> make
shell> make test
shell> make install
The make test command is important because it verifies that
the module is working. Note that when you run that command
during the DBD::mysql installation to exercise the interface
code, the MySQL server must be running or the test fails.
It is a good idea to rebuild and reinstall the DBD::mysql
distribution whenever you install a new release of MySQL.
This ensures that the latest versions of the MySQL client
libraries are installed correctly.
If you do not have access rights to install Perl modules in
the system directory or if you want to install local Perl
modules, the following reference may be useful:
http://learn.perl.org/faq/perlfaq8.html#How-do-I-keep-my-own-
module-library-directory-
2.13.2 Installing ActiveState Perl on Windows
On Windows, you should do the following to install the MySQL
DBD module with ActiveState Perl:
1. Get ActiveState Perl from
http://www.activestate.com/Products/ActivePerl/ and
install it.
2. Open a console window.
3. If necessary, set the HTTP_proxy variable. For example,
you might try a setting like this:
C:\> set HTTP_proxy=my.proxy.com:3128
4. Start the PPM program:
C:\> C:\perl\bin\ppm.pl
5. If you have not previously done so, install DBI:
ppm> install DBI
6. If this succeeds, run the following command:
ppm> install DBD-mysql
This procedure should work with ActiveState Perl 5.6 or
newer.
If you cannot get the procedure to work, you should install
the ODBC driver instead and connect to the MySQL server
through ODBC:
use DBI;
$dbh= DBI->connect("DBI:ODBC:$dsn",$user,$password) ||
die "Got error $DBI::errstr when connecting to $dsn\n";
2.13.3 Problems Using the Perl DBI/DBD Interface
If Perl reports that it cannot find the ../mysql/mysql.so
module, the problem is probably that Perl cannot locate the
libmysqlclient.so shared library. You should be able to fix
this problem by one of the following methods:
* Copy libmysqlclient.so to the directory where your other
shared libraries are located (probably /usr/lib or /lib).
* Modify the -L options used to compile DBD::mysql to
reflect the actual location of libmysqlclient.so.
* On Linux, you can add the path name of the directory
where libmysqlclient.so is located to the /etc/ld.so.conf
file.
* Add the path name of the directory where
libmysqlclient.so is located to the LD_RUN_PATH
environment variable. Some systems use LD_LIBRARY_PATH
instead.
Note that you may also need to modify the -L options if there
are other libraries that the linker fails to find. For
example, if the linker cannot find libc because it is in /lib
and the link command specifies -L/usr/lib, change the -L
option to -L/lib or add -L/lib to the existing link command.
If you get the following errors from DBD::mysql, you are
probably using gcc (or using an old binary compiled with
gcc):
/usr/bin/perl: can't resolve symbol '__moddi3'
/usr/bin/perl: can't resolve symbol '__divdi3'
Add -L/usr/lib/gcc-lib/... -lgcc to the link command when the
mysql.so library gets built (check the output from make for
mysql.so when you compile the Perl client). The -L option
should specify the path name of the directory where libgcc.a
is located on your system.
Another cause of this problem may be that Perl and MySQL are
not both compiled with gcc. In this case, you can solve the
mismatch by compiling both with gcc.
|