Browsed by
Category: 杂文

随便记点什么

远程访问MySQL数据库

远程访问MySQL数据库

Linux版本的MySQL数据库缺省不允许从远程访问(Windows版本在安装时可以进行选择),因此我们需要简单修改一下来放开这个限制。

通过软件中心安装MySQL,这没有什么好介绍的。网上有些这方面的介绍,不过中文版本的基本上都有些错误,估计大部分都只是转载,作者并没有真正尝试。

以下步骤基于Ubuntu版本。

step1:mysql> grant all privileges on *.* to 'root'@'%' identified by '1234';

其中,‘1234’是指密码,‘root‘是指远程访问的账户名。’%’是指允许从任何一个远程计算机访问。’*.*’是指所有数据库、所有表。

step2:mysql> flush privileges;

step3:修改/etc/mysql/my.cnf文件,注释掉以下行:

bind-address     = 127.0.0.1

step4: 重启MySQL服务

sudo service mysql restart

完成上述步骤后,就可以用root账户,以‘1234’为password,从任何一个远端计算机上登录并访问MySQL数据库了。

2018-09-29 更新, Debian 9之后又有了很多变化:

最大的变化莫过于MariaDB正式替换了MySQL,当然mariadb的各项操作、库(尤其是基本的操作和基本库)与MySQL还是保持兼容。同时,配置文件变更为 /etc/mysql/mariadb.conf.d/50-server.cnf。

在完成上述那些操作后,在其他用户的shell里,使用root账号登录MariaDB,会提示以下信息:

ERROR 1698 (28000): Access denied for user ‘root’@’localhost’

而直接在root用户的shell里登录是没有问题的。这种情况下,root要登录进MariaDB后,选择“mysql”数据库,然后

update user set password=password('1234') where user='root' and host='localhost';

此时设置从本机登录时,root用户的密码。

update user set plugin='' where user='root';
flush privileges;

清除root用户的plugin字段,允许root用户从其他shell里登录。

另外要注意的是,重新启动MariaDB,命令也有变换,采用 systemctl 进行操作:

systemctl stop mariadb.service
systemctl start mariadb.service
VMware player真不错

VMware player真不错

以前一直是使用VirtualBox来运行linux操作系统。原因很简单,virtualBox(简称VB)是免费的,而且功能也很不错,基本满足了我们的要求。

前几天发现VMware居然有一款VMware Player产品(简称VMP),而且从介绍看,它不仅仅是个player,它也能创建虚拟机。这可真不错。下载来试试,感觉比VB要好用些。

最让人称道的是,VMP比VB占用的内存要少得多,速度也快得多,除了系统安装以及启动那会儿,基本上客户机运行时,对主机影响不太大。主机上的各项操作仍然很流畅,而运行VB时,主机是明显受到来影响,各项操作都比较慢。

另外,VMP中的shared folder比VB的数据空间要好用些。客户机系统run起来后就能直接在/mnt目录下使用来,而VB的数据空间要进行人工进行mount(当然,也可以修改配置文件,在系统启动时mount)。相比之下,shared folder好用很多。

使用几天后,感觉很满意。将VB卸掉,换成VMP了。

linux系统产生UUID的方法

linux系统产生UUID的方法

1 #include <stdio.h>
2 #include <time.h>
3 #include <stdlib.h>
4 #include <uuid/uuid.h>
5
6 void display_uuid(uuid_t uu)
7 {
8     int i=0;
9     for(i=0; i<16; i++)
10     {
11         printf(“%02x”, uu[i]);
12     }
13
14     printf(“\n”);
15 }
16
17 int main()
18 {
19     uuid_t uu1, uu2;
20
21     uuid_generate(uu1);
22
23     uuid_generate(uu2);
24
25     display_uuid(uu1);
26
27     display_uuid(uu2);
28
29     int result = uuid_compare(uu1, uu2);
30
31     printf(“result = %d\n”, result);
32
33     return 1;
34 }
编译命令:gcc demo.c -luuid
MySQL查询结果中去掉重复的值

MySQL查询结果中去掉重复的值

一个简单的应用,查询数据库中的用户名,同时去掉其他重名的用户。测试数据库如下:

mysql> select name from demo;
+———+
| name    |
+———+
| yxh     |
| yxh     |
| default |
+———+

查询时,只要限定关键词‘distinct’即可,例如:

mysql> select distinct name from demo where name != ‘default’;
+——+
| name |
+——+
| yxh  |
+——+
1 row in set (0.02 sec)

Ubuntu 10.10发布了

Ubuntu 10.10发布了

刚才在cnbeta中看到了这个消息,感觉有点兴奋,很想知道10.10会是什么样的一个版本?是不是会带来更多的惊喜?我对ubuntu还是比较期待的,虽然同时我也比较纠结Fedora。

在ubuntu中,点击“update manager”开始check,居然没有提示升级到10.10,只是提示了几个小软件的升级。这是怎么回事?

点击”update manager”的setting按钮,检查各项配置。将release upgrade修改为”normal release”后,再进行check,提示可以升级到10.10版本了。

这就带来疑问:10.10不是LTS版本?10.04才是LTS版本,下一个LTS版本应该是11.04。

如果是这样的话,就没有太大必要着急升级到10.10。当然,潮流人士可以升级试试。

X-lite 4慢了很多

X-lite 4慢了很多

今天从xten网站上下载了最新的Xlite4,安装后感觉界面确实华丽了很多。

可是启动速度、运行速度相应也慢了很多!进到xlite的安装目录看了看,感觉xten用.net重写了xlite。.net固然很方便开发,可是我仍然觉得采用.net开发SIP客户端是个败笔,对系统要求太高了,体验不太好。

linux下的定时备份

linux下的定时备份

这个问题实际包含两个部分:

(1)创建定时任务

(2)备份数据

备份数据的命令为:rsync 例如,rsync -a /var/svn_db/ /home/backup/svn_db/

创建定时任务的命令为:crontab,例如:crontab -u root -e 编辑root用户的定时任务。此时会自动打开一个vi进行编辑, vi文件的格式为:M H D m d cmd

其中:
M: 分钟(0-59)。
H:小时(0-23)。
D:天(1-31)。
m: 月(1-12)。
d: 一星期内的天(0~6,0 表示星期天)

其中:M: 分钟(0-59)。 H:小时(0-23)。 D:天(1-31)。 m: 月(1-12)。 d: 一星期内的天(0~6,0 表示星期天)除了数字还有几个个特殊的符号就是”*”、”/”和”-“、”,”,*代表所有的取值范围内的数字,”/”代表每的意思,”*/5″表示每5个单位,”-“代表从某个数字到某个数字,”,”分开几个离散的数字。

我们的目标是创建一个定时任务,每天晚上23点开始备份数据,因此输入信息:

* 23 * * * rsync -a /var/SVN_DB/ /home/backup/svn_db/

vi保存退出后,系统会在/var/spool/cron目录下创建一个与用户名同名的文件。定时备份任务就启动了。

Fedora13特殊的网络安装方式

Fedora13特殊的网络安装方式

在一种特殊环境下安装Fedora13:

(1)无法连入internet,不能使用公网的Fedora源
(2)无DVD光驱,只有CD光驱。因此无法刻录DVD盘进行安装,只能刻录CD盘进行安装。
(3)希望在公司内部网内,通过Ftp服务器进行网络方式安装。

在网络上搜索了一下,网络安装方式通常都需要先安装windows或者dos操作系统。下面提供另外一种方式进行安装。

1. Fedora13提供了网络安装盘的iso文件(Fedora-13-i386-netinst.iso),因此我们先下载该isp文件并刻录CD启动盘。

同时,Fedora13也提供了DVD的iso文件(Fedora-13-i386-DVD.iso),同样,我们也下载该iso文件,不过不需要刻录成光盘。

2. 建立FTP server(例如,使用FileZilla server),并一定要允许匿名访问。

3. 通过7-Zip软件,将DVD iso文件中的文件全部解药到该FTP server的某个目录,例如:ftp://192.168.1.100/os/Fedora/13

下面这一步比较特殊,在GG搜索中没有搜索到结果,不得不在VirtualBox进行虚拟安装才得到的结论(其他安装方式也不需要这么特殊处理)。

4. 解压完成后,进入解压目录下的repodata目录,复制以下文件并进行改名:

将9d81a…文件复制为9d81a…-primary.sqlite.bz2
将69fe7…文件复制为69fe7…-primary.sqlite.bz2
将86ab0…文件复制为86ab0…-primary.sqlite.bz2
将37735…文件复制为37735…-primary.sqlite.bz2
将d8178…文件复制为d8178…-primary.sqlite.bz2
将27241…文件复制为27241…-filelists.sqlite.bz2
将e1153…文件复制为e1153…-Fedora-13-comps.xml.gz
将fce31…文件复制为fce31…-Fedora-13-comps.xml

5. 启动CD盘进行安装。安装过程中会提示失败,无法获取源(如果此时能访问internet,会直接寻找internet上的公告源),弹出告警对话框。此时,选择“Edit”进行编辑:

(1)设置URL为:ftp://192.168.1.100/os/Fedora/13
(2)由于该源是私有源,不在镜像列表中,因此一定要取消“URL is a mirror list”选项

点击“OK”后,系统开始安装,后面的过程与其他安装方式就没什么不同了。

如果在局域网内部已经架设了www服务器,也可以通过http方式进行安装,基本步骤应该与上述相同。

Linux下常用的几个命令

Linux下常用的几个命令

文件查找: find / -name demo.h 从根目录开始,查找文件名为”demo.h”的文件。
grep “myvoipapp” * -r 从当前目录开始搜索所有包含有字符串myvoipapp的文件, -r是指也需要搜索子目录。
查询网卡信息:ifconfig (需要root权限)
查询本机网络连接信息: netstat -a
查询CPU占用率 top
查询是否安装了mysql包: rpm -qa | grep mysql
如何以root身份登录Fedora13

如何以root身份登录Fedora13

这又是个纠结的问题。在老版本中,以root身份登录根本就不是个问题。我不太明白为什么最新的Ubuntu和Fedora都玩起了拒绝root登录的方式。

从技术上讲,屏蔽root登录方式似乎不能解决多少安全性问题。这两个发行版本的开发人员是怎么考虑的?

话说回来,以root身份登录Fedora的做法,要比Ubuntu复杂一些。采用以下方式即可:

以root身份修改以下文件:

修改文件/etc/pam.d/gdm,注释掉auth required pam_succeed_if.so user != root quiet。

修改文件/etc/pam.d/gdm-password,注释掉auth required pam_succeed_if.so user != root quiet。

然后重启系统就可以了。