Pureftpd和PostgreSQL联合使用

Pureftpd是一款在多种类Unix上使用并符合GPL协议的原代码开放的软件。那他和PostgreSQL联合使用是怎么样的看下文。

  首先,我们应该清楚PostgreSQL 是什么?PostgreSQL 是下一代 DBMS 的研究原型 POSTGRES 数据库管理系统的增强版。PostgreSQL 在保持 POSTGRES 的强大的数据模型和丰富的数据类型的基础上,用一个扩展了的 SQL 子集取代了原先的 PostQuel 查询语言。PostgreSQL 是自由的并且所有源代码都可以获得。

  PostgreSQL 的开发由参加 PostgreSQL 开发邮件列表的一个开发人员小组进行。目前的协调人是 Marc G. Fournier ([email protected] )。这个队伍现在负责 PostgreSQL 的所有开发。

  PostgreSQL 1.01 的作者是 Andrew Yu 和 Jolly Chen。还有许多其他人为移植,测试,调试和增强代码做了大量贡献。PostgreSQL 的最初起源 Postgres,是在加州大学伯克利分校的 Michael Stonebraker 教授的指导下,由许多研究生,本科生和编程职员完成的。

  这个软件最初在伯克利的名字是 Postgres。在 1995 年,当增加了 SQL 功能后,它的名字改成 Postgres95。在 1996年末,才改名为 PostgreSQL。目前***的版本是8.1.5。

  安装PostgreSQL

  我们先从www.postgresql.org下在***版本的PostgreSQL,postgresql-8.1.5.tar.gz,解压缩

 

  1.   # tar xzvf postgresql-8.1.5.tar.gz  
  2.  
  3.   # cd postgresql-8.1.5  

 

  按照快速安装方法安装

 

  1.   # ./configure  
  2.  
  3.   # gmake //一定要记得用 GNU make  
  4.  
  5.   # make install  
  6.  
  7.   # adduser postgres //同时也添加了postgres组  
  8.  
  9.   # mkdir /usr/local/pgsql/data  
  10.  
  11.   # chown postgres /usr/local/pgsql/data  
  12.  
  13.   # su - postgres  

 

  $ /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data

  $ /usr/local/pgsql/bin/postmaster -D /usr/local/pgsql/data >logfile 2>&1 & //启动数据库

  $ /usr/local/pgsql/bin/createdb test //创建一个数据库test

  $ /usr/local/pgsql/bin/psql test //用交互 psql 工具进入数据库test

  $ 退出 psql ,用 \q 命令

  设置环境变量 LD_LIBRARY_PATH

  $ vi .bash_profile

  加入

  LD_LIBRARY_PATH=/usr/local/pgsql/lib

  并在PATH=$PATH:$HOME/bin后面加入

  :/usr/local/pgsql/bin

  在 export 后加入LD_LIBRARY_PATH,并保存退出,执行

  $ source .bash_profile

  整体看起来应该是如下:

 

  1.   # .bash_profile  
  2.  
  3.   # Get the aliases and functions  

 

  if [ -f ~/.bashrc ]; then

  . ~/.bashrc

  fi

  # User specific environment and startup programs

  PATH=$PATH:$HOME/bin:/usr/local/pgsql/bin

  LD_LIBRARY_PATH=/usr/local/pgsql/lib

  export PATH LD_LIBRARY_PATH

  unset USERNAME

  $ psql -l //查看现有数据库

  $ psql //进入psql交互模式

  =# CREATE USER pureftpd WITH PASSWORD ‘ pureftpd ‘;

  =# CREATE DATABASE pureftpd WITH OWNER = pureftpd TEMPLATE = template0 ENCODING = ‘EUC_CN’;

  =# \q

  $ psql -l

  List of databases

  Name | Owner | Encoding

  ———–+———-+———-

  postgres | postgres | UTF8

  pureftpd | pureftpd | EUC_CN

  template0 | postgres | UTF8

  template1 | postgres | UTF8

  test | postgres | UTF8

  (5 rows)

  $ createlang plpgsql pureftpd

  $ psql -U pureftpd

  pureftpd=>

  DROP TABLE users CASCADE;

  DROP SEQUENCE users_id_seq CASCADE;

  CREATE TABLE “users” (

  id integer DEFAULT nextval(‘users_id_seq’::text) NOT NULL,

  ”User” character varying(16) NOT NULL default ”,

  status smallint default 0, //这个参数没用上

  ”Password” character varying(64) NOT NULL default ”,

  ”Uid” character varying(11) DEFAULT -1 NOT NULL,

  ”Gid” character varying(11) DEFAULT -1 NOT NULL,

  ”Dir” character varying(128) NOT NULL,

  ”comment” text,

  ipaccess character varying(15) DEFAULT ‘*’ NOT NULL,

  ”ULBandwidth” smallint default 0,

  ”DLBandwidth” smallint default 0,

  ”QuotaSize” integer DEFAULT 0,

  ”QuotaFiles” integer DEFAULT 0,

  ULRatio smallint default 0,

  DLRatio smallint default 0,

  create_date timestamp with time zone DEFAULT now() NOT NULL,

  modify_date timestamp without time zone DEFAULT now() NOT NULL

  );

  CREATE SEQUENCE users_id_seq;

  CREATE INDEX users_index ON users (id,”User”);

  ALTER TABLE ONLY users ADD CONSTRAINT users_pkey PRIMARY KEY (id);

  ALTER TABLE ONLY users ADD CONSTRAINT users_id_key UNIQUE (id, “User”);

  pureftpd=> \d

  List of relations

  Schema | Name | Type | Owner

  ——–+————–+———-+———-

  public | users | table | pureftpd

  public | users_id_seq | sequence | pureftpd

  (2 rows)

  pureftpd=> INSERT INTO users VALUES (1, ‘test’, 1, md5(‘test’), ‘2000’, ‘2000’, ‘/var/ftp/test’, ”, ‘*’, 0, 0, 0, 0, 0, 0, ‘2006-11-27 14:30:00’, ‘2006-11-27 14:30:00’);

  这样,数据库就建立完成了,然后我们配置pureftpd-pgsql.conf 文件

 

  1.   # vi /usr/local/pureftpd/etc/pureftpd-pgsql.conf  

 

  这个和我们前面看到的mysql的配置文件类似,修改也类似,我这里就不赘述了。

  注意:在pureftpd-pgsql.conf中密码加密我用的是

  PGSQLCrypt md5

  我没有看到crypt或encrypt函数,如果大家有这方面知识的话,欢迎探讨。

  另外一个非常重要,你需要修改

  PGSQLGetRatioUL SELECT ULRatio FROM users WHERE User=’\L’

  PGSQLGetRatioDL SELECT DLRatio FROM users WHERE User=’\L’

  为

  PGSQLGetRatioUL SELECT “ULRatio” FROM “users” WHERE “User”=’\L’

  PGSQLGetRatioDL SELECT “DLRatio” FROM “users” WHERE “User”=’\L’

  格式,否则是不能认证的。

  修改pure-ftpd.conf 文件,和mysql一样,就改一条

  PGSQLConfigFile /usr/local/pureftpd/etc/pureftpd-pgsql.conf

  重新启动pureftpd程序后测试,和用mysql数据库认证时的权限相同。

通过文章的描写,我们不难发现Pureftpd和PostgreSQL联合使用效果挺好的,希望对大家有帮助!

【编辑推荐】

  1. Pureftpd 命令语法
  2. Pureftpd配置之虚拟用户支持
  3. Pureftpd配置之系统真实用户
  4. Pureftpd配置之匿名用户登陆
  5. Pureftpd安装文档
  6. 中文解释PureFTPd配置文件

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/250465.html<

(0)
运维的头像运维
上一篇2025-04-28 12:47
下一篇 2025-04-28 12:49

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注