postfix+dovecot+postfixadmin 搭建邮件服务器

本贴最后更新于 2424 天前,其中的信息可能已经事过景迁

1. LNMP环境搭建

1.1 nginx安装配置

systemctl stop firewalld

setenforce 0

yum install epel-release -y

yum update

yum install vim nginx net-tools wget -y

cd /etc/nginx

mv nginx.conf nginx.bak

vim nginx.conf

user  nginx;
pid /var/run/nginx.pid;
worker_processes  4;
events {
    use epoll;
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    include /etc/nginx/proxy.conf;
    sendfile        on;
    keepalive_timeout  65;
    include /etc/nginx/vhosts/*.conf;
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.php index.html index.htm;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
    }
}

vim proxy.conf

#!nginx (-)
# proxy.conf
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 64m;
client_body_buffer_size 128k;
proxy_connect_timeout 120;
proxy_send_timeout 120;
proxy_read_timeout 120;
send_timeout 600;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
proxy_headers_hash_max_size 51200;
proxy_headers_hash_bucket_size 6400;

vim gzip.conf

gzip on;
# gzip_http_version 1.1;
gzip_disable "MSIE [1-6]\.";
gzip_disable "Mozilla/4";
gzip_comp_level 3;
gzip_proxied any;
gzip_vary on;
gzip_buffers 4 16k;
gzip_min_length 1100;
gzip_types text/plain text/xml text/css applicatoin/xml application/xhtml+xml application/rss+xml application/atom_xml application/javascript application/x-javascript;

mkdir vhosts;cd vhosts

vim mailserver.conf

server {
        listen 80;
        server_name mail-admin.meskvm.com;
        index index.php;
        root /usr/local/postfixadmin;    #postfixadmin目录
    location ~ \.php$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
    }

}
server {
listen 80;
server_name mail.meskvm.com;
index index.php;
root /data/nginx/roundcube; #roundcube 目录

    location ~ \.php$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
    }<br />}

systemctl start nginx

systemctl enable nginx

1.2 php安装配置

yum install php php-fpm lighttpd-fastcgi php-adodb php-bcmath php-Analog php-cli php-dba php-devel php-embedded php-enchant php-gd php-geshi php-getid3 php-gliph php-hamcrest php-idn php-imap php-interbase php-intl php-latte php-layers-menu php-ldap php-lessphp php-libdmtx php-libpuzzle php-magickwand php-mapi php-mapserver php-markdown php-masterminds-html5 php-mbstring php-mcrypt php-mysql php-odbc php-pclzip php-pdo php-pear php-pecl php-phpass php-process php-spsell php-punic php-recode php-redis php-redland php-scssphp php-sentry php-shout php-silex php-simplepie php-snmp php-soap php-tcpdf php-tidy php-tracy php-twig php-voms-admin php-when php-xapian php-xcache php-xml php-xmlrpm php-zipstream php-zmq php-zte -y

vim /etc/php.ini           #修改以下内容

date.timezone = "Asia/Shanghai"
session.save_path = "/dev/shm"
post_max_size = 128M
upload_max_filesize = 128M

systemctl start php-fpm

systemctl enable php-fpm

1.3 mariadb安装配置

yum install mariadb mariadb-server mariadb-libs -y

systemctl start mariadb

mysqladmin -u root password

systemctl restart mariadb

mysql -u root -p

MariaDB [(none)]> create database postfix character set utf8;
MariaDB [(none)]> grant all privileges on postfix.* to postfix@localhost identified by ‘postfix’;
MariaDB [(none)]> create database roundcubemail character set utf8;
MariaDB [(none)]> grant all privileges on roundcube.* to postfix@localhost identified by ‘postfix’;
MariaDB [(none)]> flush privileges;

mariadb enable mariadb

2. 邮件服务相关组件安装配置

2.1 postfix安装配置

yum install postfix -y

cd /etc/postfix

mv main.cf main.bak

vim main.cf

###############MAIN    CONFIGURE###################
myhostname = mail.meskvm.com 
mydomain = meskvm.com
myorigin = $mydomain
inet_interfaces = all
mydestination = localhost
mynetworks = 0.0.0.0/0
disable_dns_lookups = no
default_destination_concurrency_limit = 80
default_process_limit = 100
mail_max_userip_connections = 50
net_interfaces = ipv4

###############Virtual mail configure#############
virtual_mailbox_domains = proxy:mysql:/etc/postfix/mysql_virtual_domains_maps.cf
virtual_alias_maps = proxy:mysql:/etc/postfix/mysql_virtual_alias_maps.cf
virtual_mailbox_maps = proxy:mysql:/etc/postfix/mysql_virtual_mailbox_maps.cf
vitual_mailbox_base = /data/mailbox
virtual_mailbox_limit_maps = mysql:/etc/postfix/mysql_virtual_mailbox_limit_maps.cf
virtual_uid_maps = static:8
virtual_gid_maps = static:12
virtual_transport = dovecot
dovecot_destination_recipient_limit = 1
proxy_read_maps = local_recipient_maps mydestination virtual_alias_maps virtual_alias_domains virtual_mailbox_maps virtual_mailbox_domains relay_recipient_maps relay_domains canonical_maps sender_canonical_maps recipient_canonical_maps relocated_maps transport_maps mynetworks $virtual_mailbox_limit_maps
###############SASL SUPPORT FOR CLIENTS############
smtpd_sasl_auth_enable = yes
smtpd_sasl_type = dovecot
smtpd_sasl_security_options = noanonymous
smtpd_sasl_path = private/auth
smtpd_sasl_local_domain = $mydomain
broken_sasl_auth_clients = yes
smtpd_sender_login_maps = mysql:/etc/postfix/mysql_sender_login_maps.cf, mysql:/etc/postfix/mysql_virtual_alias_maps.cf
##########mail monitor##########
recipient_bcc_maps = hash:/etc/postfix/recipient_bcc
sender_bcc_maps = hash:/etc/postfix/sender_bcc
smtpd_sender_restrictions = reject_sender_login_mismatch, reject_authenticated_sender_login_mismatch, reject_non_fqdn_sender,
check_recipient_access hash:/etc/postfix/local_recipient

smtpd_recipient_restrictions = check_sender_access hash:/etc/postfix/local_senders, permit_sasl_authenticated, reject_invalid_hostname, reject_non_fqdn_hostname, reject_unknown_sender_domain, reject_non_fqdn_sender, reject_non_fqdn_recipient, reject_unknown_recipient_domain, reject_unauth_pipelining, reject_unauth_destination, reject_sender_login_mismatch, reject_authenticated_sender_login_mismatch
smtpd_tls_key_file = /etc/pki/dovecot/private/dovecot.pem
smtpd_tls_cert_file = /etc/pki/dovecot/certs/dovecot.pem
smtpd_tls_loglevel = 1
smtpd_tls_received_header = yes
smtpd_tls_session_cache_timeout = 3600s
smtp_connect_timeout = 120s
tls_random_source = dev:/dev/urandom
###############Mail Quota configure###############
message_size_limit = 204800000
maximal_queue_lifetime = 1d
bounce_queue_lifetime = 1d
#####sendgroupmail contraint#########
smtpd_restriction_classes = send_all, local_only
send_all = check_sender_access hash:/etc/postfix/send_all, reject
local_only = check_recipient_access hash:/etc/postfix/my_rcpt, reject

mv master.cf master.bak

vim master.cf

smtp     inet   n     -     n       -       -       smtpd
submission inet  n    -     n       -       -       smtpd
 -o smtpd_tls_security_level=encrypt
 -o smtpd_sasl_auth_enable=yes
 -o smptd_sasl_path=private/auth
 -o smtpd_sasl_security_options=noanonymous
 -o smtpd_sasl_local_domain=$myhostname
 -o smtpd_client_restrictions=permit_sasl_authenticated,reject
 -o smtpd_sender_login_maps=hash:/etc/postfix/virtual
 -o smtpd_sender_restrictions=reject_sender_login_mismatch
 -o smtpd_recipient_restrictions=reject_non_fqdn_recipient,reject_unknown_recipient_domain,permit_sasl_authenticated,reject
smtps      inet  n       -       n       -       -       smtpd
 -o smtpd_tls_wrappermode=yes
 -o smtpd_sasl_auth_enable=yes
 -o smtpd_client_restrictions=permit_sasl_authenticated,reject
pickup     unix  n       -       n       60      1       pickup
 -o content_filter= -o receive_override_options=no_header_body_checks
cleanup    unix  n       -       n       -       0       cleanup
qmgr       unix  n       -       n       300     1       qmgr
tlsmgr     unix  -       -       n       1000?   1       tlsmgr
rewrite    unix  -       -       n       -       -       trivial-rewrite
bounce     unix  -       -       n       -       0       bounce
defer      unix  -       -       n       -       0       bounce
trace      unix  -       -       n       -       0       bounce
verify     unix  -       -       n       -       1       verify
flush      unix  n       -       n       1000?   0       flush
proxymap   unix  -       -       n       -       -       proxymap
proxywrite unix  -       -       n       -       1       proxymap
smtp       unix  -       -       n       -       -       smtp
relay      unix  -       -       n       -       -       smtp
showq      unix  n       -       n       -       -       showq
error      unix  -       -       n       -       -       error
retry      unix  -       -       n       -       -       error
discard    unix  -       -       n       -       -       discard
local      unix  -       n       n       -       -       local
virtual    unix  -       n       n       -       -       virtual
lmtp       unix  -       -       n       -       -       lmtp
anvil      unix  -       -       n       -       1       anvil
scache     unix  -       -       n       -       1       scache
maildrop   unix  -       n       n       -       -       pipe
 flags=DRhu user=mail argv=/usr/local/bin/maildrop -d ${recipient}
uucp       unix  -       n       n       -       -       pipe
 flags=Fqhu user=uucp argv=uux -r -n -z -a$sender - $nexthop!rmail ($recipient)
ifmail     unix  -       n       n       -       -       pipe
 flags=F user=ftn argv=/usr/lib/ifmail/ifmail -r $nexthop ($recipient)
bsmtp      unix  -       n       n       -       -       pipe
 flags=Fq. user=bsmtp argv=/usr/local/sbin/bsmtp -f $sender $nexthop $recipient
dovecot    unix  -       n       n       -       -       pipe
 flags=DRhu user=mail:mail argv=/usr/libexec/dovecot/deliver -f ${sender} -d ${recipient}
vacation   unix  -       n       n       -       -       pipe
 flags=Rq user=vacation argv=/var/spool/vacation/vacation.pl -f ${sender} -d ${recipient}

vim mysql_relay_domains_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
query = SELECT domain FROM domain WHERE domain='%s' AND backupmx = '1'

vim mysql_sender_login_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
#query = SELECT username FROM mailbox WHERE username = '%s' AND active = '1'
table = mailbox
select_field = username
where_field = username

vim mysql_virtual_alias_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
query = SELECT goto FROM alias WHERE address='%s' AND active = '1'
#table = alias
#select_field = goto
#where_filed = address

vim mysql_virtual_domains_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
query = SELECT domain FROM domain WHERE domain='%s' AND active = '1'
#table = domain
#select_field = domain
#where_field = domain

vim mysql_virtual_mailbox_limit_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
query = SELECT quota FROM mailbox WHERE username='%s' AND active = '1'
#table = mailbox
#select_field = quota
#where_field = username

vim mysql_virtual_mailbox_maps.cf

hosts = localhost
#port = 23306
user = postfix
password = postfix
dbname = postfix
query = SELECT maildir FROM mailbox WHERE username='%s' AND active = '1'
#table = mailbox
#select_field = maildir
#where_field = username

echo "meskvm.com OK" > local_domains

postmap hash:/etc/postfix/local_domains

systemctl start postfix

systemctl enable postfix

2.1 dovecot安装配置

yum install dovecot* -y

cd /etc/dovecot

mv dovecot.conf dovecot.bak

vim dovecot.conf

# 2.2.10: /etc/dovecot/dovecot.conf
# OS: Linux 3.10.0-514.el7.x86_64 x86_64 CentOS Linux release 7.3.1611 (Core)  xfs
auth_mechanisms = plain login cram-md5
dict {
  quotadict = mysql:/etc/dovecot/dovecot-dict-quota.conf
}
disable_plaintext_auth = no
first_valid_gid = 12
first_valid_uid = 8
info_log_path = /var/log/dovecot_info.log
listen = *
log_path = /var/log/dovecot.log
mail_location = maildir:/data/mailbox/%d/%n
mail_max_userip_connections = 50
mail_plugins = quota
managesieve_notify_capability = mailto
managesieve_sieve_capability = fileinto reject envelope encoded-character vacation subaddress comparator-i;ascii-numeric relational regex imap4flags copy include variables body enotify environment mailbox date
mbox_write_locks = fcntl
passdb {
  args = /etc/dovecot/dovecot-sql.conf
  driver = sql
}
plugin {
  autocreate = Trash
  autocreate2 = Junk
  autocreate3 = Drafts
  autocreate4 = Sent
  autosubscribe = Trash
  autosubscribe2 = Junk
  autosubscribe3 = Drafts
  autosubscribe4 = Sent
  quota = dict:user::proxy::quotadict
  quota_rule = *:storage=2G
}
service auth {
  unix_listener /var/spool/postfix/private/auth {
    group = postfix
    mode = 0600
    user = postfix
  }
  unix_listener auth-client {
    group = mail
    mode = 0600
    user = mail
  }
  unix_listener auth-userdb {
    group = mail
    mode = 0600
    user = mail
  }
}
service dict {
  unix_listener dict {
    group = mail
    mode = 0600
    user = mail
  }
}
service imap-login {
  inet_listener imap {
    port = 143
  }
  inet_listener imaps {
    port = 993
    ssl = yes
  }
}
service pop3-login {
  inet_listener pop3 {
    port = 110
  }
  inet_listener pop3s {
    port = 995
    ssl = yes
  }
}
ssl_cert = </etc/pki/dovecot/certs/dovecot.pem
ssl_key = </etc/pki/dovecot/private/dovecot.pem
userdb {
  args = /etc/dovecot/dovecot-sql.conf
  driver = sql
}
protocol lda {
  mail_plugins = quota
}
protocol pop3 {
  mail_plugins = quota
  pop3_client_workarounds = outlook-no-nuls oe-ns-eoh
  pop3_uidl_format = %08Xu%08Xv
}
protocol imap {
  mail_plugins = quota imap_quota autocreate
}

vim dovecot-dict-quota.conf

map {
	pattern = priv/quota/storage
	table = quota2
	username_field = username
	value_field = bytes
}
map {
	pattern = priv/quota/messages
	table = quota2
	username_field = username
	value_field = messages
}

vim dovecot-sql.conf

driver = mysql
connect = host=localhost dbname=postfix user=postfix password=postfix
default_pass_scheme = MD5

#following should all be on one line
password_query = SELECT username as user, password, concat('/data/mailbox/', maildir) as userdb_home, concat('maildir:/data/mailbox', maildir) as userdb_mail, 8 as userdb_uid, 12 as userdb_gid FROM mailbox WHERE username = '%u' AND active = '1'
#user
user_query = SELECT concat('/data/mailbox/', maildir) as home, concat('maildir:/data/mailbox/', maildir) as mail, 8 AS uid, 12 AS gid, CONCAT('*:messages=100000:bytes=', quota) as quota_rule FROM mailbox WHERE username = '%u'AND active = '1'

systemctl start dovecot

systemctl enable dovecot

2.3 postfixadmin安装配置

cd /usr/local/src

wget https://sourceforge.net/projects/postfixadmin/files/postfixadmin/postfixadmin-3.0.2/postfixadmin-3.0.2.tar.gz

tar -zxvf postfixadmin-3.0.2.tar.gz

mv postfixadmin-3.0.2 /usr/local/postfixadmin

cd /usr/local/postfixadmin

vim config.inc.php           #打开配置文件并修改以下内容

$CONF['configured'] = true;
$CONF['default_language'] = 'cn';
$CONF['database_type'] = 'mysql';
$CONF['database_type'] = 'mysql';
$CONF['database_host'] = 'localhost';
$CONF['database_user'] = 'postfix';
$CONF['database_password'] = 'postfix';
$CONF['database_name'] = 'postfix';
$CONF['encrypt'] = 'dovecot:CRAM-MD5';
$CONF['dovecotpw'] = "/usr/bin/doveadm pw";
$CONF['quota'] = 'YES';

在浏览器打开页面mail-admin.meskvm.com/setup.php 如下图

按照提示修改config.inc.php相关内容,并创建安装密码,并创建管理员和密码。 如下图

按照提示转入登陆页,并登录。原目录下的setup.php文件可删除。 登录页面如下图所示

创建域 如下图所示

创建用户 如下图

2.3 roundcube安装配置

cd /usr/local/src

wget https://github.com/roundcube/roundcubemail/releases/download/1.2.5/roundcubemail-1.2.5.tar.gz

tar -zxvf roundcubemail-1.2.5.tar.gz

mv roundcubemail-1.2.5 /data/nginx/roundcube

cd /data/nginx/roundcube

cp config/config.inc.php.sample config/config.inc.php

vim config/config.inc.php     #修改以下内容

$config['db_dsnw'] = 'mysql://postfix:postfix@localhost/roundcubemail';
$config['smtp_server'] = 'ssl://mail.meskvm.com';
$config['smtp_port'] = 465;
$config['smtp_user'] = '%u';
$config['smtp_pass'] = '%p';

mysql -u postfix -ppostfix roundcubemail < SQL/mysql_initial.sql

用浏览器打开地址 mail.meskvm.com从网页登录邮箱。如下图

为roundcube安装修改密码插件

vim config/config.inc.php               #打开配置文件并修改以下内容

$config['plugins'] = array(

    'archive',

'zipdownload',

'password',

);

cd plugins/password

cp config.inc.php.dist config.inc.php

vim config.inc.php            #打开配置文件并修改以下内容

$config['password_dovecotpw'] = '/usr/bin/doveadm pw';
$config['password_db_dsn'] = 'mysql://postfix:postfix@localhost/postfix';
$config['password_query'] = 'UPDATE mailbox SET password=%D WHERE username=%u';
// $config['password_crypt_hash'] = 'md5';
$config['password_dovecotpw_with_method'] = true;

在网页端修改用户密码。如下图

为roundcube安装公共通讯录插件

cd /data/nginx/roundcube/plugins

git clone  https://github.com/JohnDoh/Roundcube-Plugin-Global-Address-Book.git

mv Roundcube-Plugin-Global-Address-Book globaladdressbook

vim ../config/config.inc.php                #打开配置文件修改以下内容

$config['plugins'] = array(
    'archive',
    'zipdownload',
    'password',
    'globaladdressbook',
);

mv globaladdressbook/config.inc.php.dist globaladdressbook/config.inc.php

vim globaladdressbook/config.inc.php                   #打开文件并修改以下内容

$config['globaladdressbook_user'] = '[global_addressbook@%d]';
$config['globaladdressbook_perms'] = 3;
$config['globaladdressbook_admin'] = 'test@meskvm.com';

测试并查看公共通讯录。 如下图

  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    915 引用 • 931 回帖
  • mailserver
    1 引用

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    51 引用 • 190 回帖
  • OnlyOffice
    4 引用 • 23 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 407 关注
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    536 引用 • 672 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 1 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    189 引用 • 1056 回帖
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    90 引用 • 383 回帖 • 1 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 429 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    76 引用 • 421 回帖
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 497 关注
  • 安全

    安全永远都不是一个小问题。

    189 引用 • 813 回帖 • 1 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    91 引用 • 751 回帖 • 1 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    180 引用 • 447 回帖 • 1 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    492 引用 • 1383 回帖 • 374 关注
  • GraphQL

    GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。

    4 引用 • 3 回帖 • 20 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 592 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 2 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 238 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    18722 引用 • 69932 回帖
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 4 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 643 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 370 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    76 引用 • 37 回帖 • 1 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 6 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 25 关注
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    82 引用 • 122 回帖 • 620 关注