[转]MySQL 5.1.56 for Windows XP/Vista/7

MySQL 5.1.56 for Windows XP/Vista/7

Building a Web Server, for Windows

http://www.devside.net/guides/windows/mysql 

Requirements

  • None

Download

Our Configuration

  • %SYSTEMROOT% : C:\Windows
  • Install to : C:\www\mysql

Setup

  • Unpack as C:\www\mysql-5.1.56-win32
  • Rename directory C:\www\mysql-5.1.56-win32 to C:\www\mysql
  • Copy MySQL configuration file C:\www\mysql\my-medium.ini (or your choice of one of the other included my-*.ini files) to your %SYSTEMROOT% directory
  • Rename file %SYSTEMROOT%\my-medium.ini (or the copied over my-*.ini file) to my.ini
  • Edit %SYSTEMROOT%\my.ini
    • Under Sections "[client]" and "[mysqld]", edit...
      • socket = C:/www/tmp/mysql.sock
    • Under Section "[mysqld]", insert...
      • basedir = C:/www/mysql/
      • datadir = C:/www/mysql/data/

MySQL Server Binaries

MySQL ships with a number of server binaries to choose from. For standard/typical use and functionality, the preference is for server binary 'mysqld'.

  • mysqld.exe: Support for symbolic links, InnoDB and BDB transactional tables, and named pipes.
  • mysql-debug.exe: Compiled with full debugging and automatic memory allocation checking, symbolic links, and InnoDB and BDB transactional tables.

Startup

MySQL can be installed as a Service (automatic or manual start-up) or started as a standalone console application. The MySQL server can be configured to listen (and communicate) on all interfaces (0.0.0.0), the loopback (127.0.0.1), or any other address. The MySQL server can also be configured to skip networking (TCP/IP) and/or connect via named-pipes (sockets).

  • Install the MySQL process as a Service.
    • [Default] Listen on all interfaces (0.0.0.0)...
      • For MySQL automatic start (but not this first time):mysqld --installOr for MySQL manual start only:mysqld --install-manual
    • Other options (edit my.ini), section '[mysqld]', insert...
      • Listen on loopback only (127.0.0.1)...
        bind-address=127.0.0.1
      • Do not use TCP/IP (IP addresses and ports) for connections, use named-pipes...
        bind-address=localhostskip-networkingenable-named-pipe[Note option socket=C:/www/tmp/mysql.sock (default is 'socket=MySQL' for mysql and php) under sections '[client]' and '[mysqld]'; Make sure the specifed dir exists; Make sure to fill php.ini options mysql[i].default_socket = C:/www/tmp/mysql.sock and mysql[i].default_host = localhost; Use mysql[i]_connect('localhost:/www/tmp/mysql.sock', 'user', 'password')]
    • Start the MySQL Service...
      ...> NET START MySQL
  • Start MySQL as a standalone console application.
    • C:\www\mysql\bin> mysqld --standalone --console
    • [option '--standalone': Dummy option to start as a standalone server; can be omitted and have the same effect]
    • [option '--console': Write error output on screen (as opposed to error log)]
    • Other command line arguments...
      • IP address to bind to:--bind-address=127.0.0.1
      • Bypass TCP/IP with named pipes:--skip-networking --enable-named-pipe --socket=mysql.sock
      • [option '--skip-networking': do not use TCP/IP -- only valid for localhost]
      • [option '--enable-named-pipe': allows connections to other NT machines without being dependant on a specific network layer (TCP/IP or IPX)]
      • [option '--socket=...': name of nt-pipe/socket to use for option '--enable-named-pipe']

Cleanup

  • Create a password for the 'root' mysql account...
    • C:\www\mysql\bin> mysqladmin -u root password set-root-password-here
  • Delete all insecure users...
    • Access the MySQL prompt...
      • C:\www\mysql\bin> mysql -u root -p
    • Display all databases, accounts, and access controls to individual databases...
      • mysql> SHOW DATABASES;
      • mysql> SELECT User, Host, Password FROM mysql.user;
      • mysql> SELECT Host, Db, User, Select_priv FROM mysql.db;
    • Remove all initial accounts except 'root@localhost'; remove 'test' database and privileges set...
      • Remove anonymous users:mysql> DELETE FROM mysql.user WHERE User='';
      • Remove remote root:mysql> DELETE FROM mysql.user WHERE User='root' AND Host != 'localhost';
      • Remove test database:mysql> DROP DATABASE test;
      • Remove privileges on test database:mysql> DELETE FROM mysql.db WHERE Db = 'test' OR Db = 'test\\_%';
      • mysql> FLUSH PRIVILEGES;
    • Exit.
      • mysql> quit;

Running MySQL

All commands are run from the command line and directory C:\www\mysql\bin (unless the mentioned dir is under the PATH)

  • Enter the command-line interface...
    > mysql -u root -p
  • Stop the MySQL Service (one of two ways)...
    > NET STOP MySQL
    > mysqladmin -u root -p shutdown
  • Uninstall the MySQL Service...
    > mysqld --remove
  • Shutdown the standalone console MySQL application (one of two ways)...
    > mysqladmin -u root -p shutdown[Note that this is done from another cmd.exe window]
    Ctrl-C under the cmd.exe window it was started from

Help

All commands are run from the command line and directory C:\www\mysql\bin (unless the mentioned dir is under the PATH)

  • Display the MySQL command-line interface (shell) options...
    > mysql --help
  • Display mysqld options...
    > mysqld --help
  • Display MySQL version information...
    > mysqladmin -V
  • See what values a running MySQL server is using...
    > mysqladmin -u <user> -p<password> variables
  • Display information...
    > mysqladmin -u <user> -p<password> version status proc
  • Update password for MySQL user 'root' (from the MySQL shell)...
    mysql> UPDATE mysql.user SET Password=PASSWORD('root-password') WHERE User='root';
    mysql> FLUSH PRIVILEGES;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值