ansible 的 inventory

本贴最后更新于 1703 天前,其中的信息可能已经水流花落

一、work with inventory

Ansible 可同时处理基础架构中的多个系统。它通过选择 Ansible 库存中列出的系统部分来实现这一点,该系统默认保存在该位置/etc/ansible/hosts。您可以使用命令行上的选项指定其他清单文件。-i

此库存不仅可配置,而且您还可以同时使用多个库存文件,并从动态或云源或不同格式(YAML,ini 等)中提取库存,如使用动态库存中所述。Ansible 在 2.4 版本中引入了库存插件,使其具有灵活性和可定制性。

库存基础:主机和组
清单文件可以采用多种格式之一,具体取决于您拥有的库存插件。对于此示例,格式为/etc/ansible/hosts 类似 INI(Ansible 的默认值之一),如下所示:

mail.example.com

[webservers]
foo.example.com
bar.example.com

[dbservers]
one.example.com
two.example.com
three.example.com

括号中的标题是组名,用于分类系统并决定您在什么时间和目的控制哪些系统。

YAML 版本看起来像:

all:
  hosts:
    mail.example.com:
  children:
    webservers:
      hosts:
        foo.example.com:
        bar.example.com:
    dbservers:
      hosts:
        one.example.com:
        two.example.com:
        three.example.com:
多个组中的主机

您可以将系统放在多个组中,例如,服务器既可以是 Web 服务器,也可以是特定数据中心。例如,您可以创建跟踪的组:

什么 - 应用程序,堆栈或微服务。(例如,数据库服务器,Web 服务器等)。
Where - 数据中心或区域,与本地 DNS,存储等通信(例如,东,西)。
何时 - 开发阶段,避免测试生产资源。(例如,prod,test)。
扩展之前的 YAML 库存以包括什么,何时和何处:

all:
  hosts:
    mail.example.com:
  children:
    webservers:
      hosts:
        foo.example.com:
        bar.example.com:
    dbservers:
      hosts:
        one.example.com:
        two.example.com:
        three.example.com:
    east:
      hosts:
        foo.example.com:
        one.example.com:
        two.example.com:
    west:
      hosts:
        bar.example.com:
        three.example.com:
    prod:
      hosts:
        foo.example.com:
        one.example.com:
        two.example.com:
    test:
      hosts:
        bar.example.com:
        three.example.com:

你可以看到,one.example.com 在存在着 dbservers,east 和 prod 团体。

你也可以使用嵌套组来简化 prod 并 test 在此盘点,对于相同的结果:

all:
  hosts:
    mail.example.com:
  children:
    webservers:
      hosts:
        foo.example.com:
        bar.example.com:
    dbservers:
      hosts:
        one.example.com:
        two.example.com:
        three.example.com:
    east:
      hosts:
        foo.example.com:
        one.example.com:
        two.example.com:
    west:
      hosts:
        bar.example.com:
        three.example.com:
    prod:
      children:
        east:
    test:
      children:
        west:

如果您确实有多个组中的系统,请注意变量将来自它们所属的所有组。变量优先级在变量优先级中详细说明:我应该在哪里放置变量?。

主机和非标准端口
如果您拥有在非标准 SSH 端口上运行的主机,则可以在主机名后面添加带冒号的端口号。SSH 配置文件中列出的端口不会与 paramiko 连接一起使用,但会与 openssh 连接一起使用。

为了使事情明确,建议您在默认端口上没有运行时设置它们:

badwolf.example.com:5309

假设您只有静态 IP,并且想要设置一些存在于主机文件中的别名,或者您正在通过隧道连接。您还可以通过变量描述主机:

在 INI:

jumper ansible_port=5555 ansible_host=192.0.2.50

在 YAML:

...
  hosts:
    jumper:
      ansible_port: 5555
      ansible_host: 192.0.2.50

在上面的示例中,尝试对主机别名“jumper”(可能甚至不是真正的主机名)进行回复,将在端口 5555 上联系 192.0.2.50。请注意,这是使用库存文件的一个功能来定义一些特殊变量。一般来说,这不是定义描述系统策略的变量的最佳方式,但我们将在稍后分享建议。

注意

使用 key=value 语法以 INI 格式传递的值根据声明的位置进行不同的解释。*当与主机内联声明时,INI 值被解释为 Python 文字结构(字符串,数字,元组,列表,dicts,布尔值,无)。主机线 key=value 每行接受多个参数。因此,他们需要一种方法来指示空间是值的一部分而不是分隔符。*在:vars 节中声明时,INI 值被解释为字符串。例如,var=FALSE 将创建一个等于'FALSE'的字符串。与主机行不同,:vars 段每行只接受一个条目,所以后面的所有内容都是=必须是条目的值。*不要依赖于定义期间设置的类型,在使用变量时,请务必确保在需要时使用过滤器指定类型。*考虑将 YAML 格式用于库存源,以避免混淆变量的实际类型。YAML 清单插件一致且正确地处理变量值。

如果要添加大量遵循类似模式的主机,则可以执行此操作而不是列出每个主机名:

在 INI:

[webservers]
www[01:50].example.com

在 YAML:

...
  webservers:
    hosts:
      www[01:50].example.com:

对于数字模式,可以根据需要包含或删除前导零。范围包括在内。您还可以定义字母范围:

[databases]
db-[a:f].example.com

您还可以基于每个主机选择连接类型和用户:

[targets]
localhost              ansible_connection=local
other1.example.com     ansible_connection=ssh        ansible_user=mpdehaan
other2.example.com     ansible_connection=ssh        ansible_user=mdehaan

如上所述,在库存文件中设置这些只是一种简写,稍后我们将讨论如何将它们存储在 'host_vars' 目录中的单个文件中。

将变量分配给一台机器:主机变量
如上所述,很容易将变量分配给稍后将在 playbooks 中使用的主机:

[atlanta]
host1 http_port=80 maxRequestsPerChild=808
host2 http_port=303 maxRequestsPerChild=909

YAML 版本:

atlanta:
  host1:
    http_port: 80
    maxRequestsPerChild: 808
  host2:
    http_port: 303
    maxRequestsPerChild: 909

为多台机器分配变量:组变量
变量也可以同时应用于整个组:

INI 方式:

[atlanta]
host1
host2

[atlanta:vars]
ntp_server=ntp.atlanta.example.com
proxy=proxy.atlanta.example.com

YAML 版本:

atlanta:
  hosts:
    host1:
    host2:
  vars:
    ntp_server: ntp.atlanta.example.com
    proxy: proxy.atlanta.example.com

请注意,这只是一次将变量应用于多个主机的便捷方式; 即使您可以按组定位主机,在执行播放之前,变量始终会展平到主机级别。

继承变量值:组的组变量
您可以使用:childrenINI 中的后缀或 children:YAML 中的条目来创建组。您可以使用:vars 或将变量应用于这些组的组 vars::

[atlanta]
host1
host2

[raleigh]
host2
host3

[southeast:children]
atlanta
raleigh

[southeast:vars]
some_server=foo.southeast.example.com
halon_system_timeout=30
self_destruct_countdown=60
escape_pods=2

[usa:children]
southeast
northeast
southwest
northwest
all:
  children:
    usa:
      children:
        southeast:
          children:
            atlanta:
              hosts:
                host1:
                host2:
            raleigh:
              hosts:
                host2:
                host3:
          vars:
            some_server: foo.southeast.example.com
            halon_system_timeout: 30
            self_destruct_countdown: 60
            escape_pods: 2
        northeast:
        northwest:
        southwest:

如果您需要存储列表或哈希数据,或者希望将主机和组特定变量与库存文件分开,请参阅下一节。儿童团体有几个要注意的属性:

作为子组成员的任何主机都自动成为父组的成员。
子组的变量将具有更高的优先级(覆盖)父组的变量。
群组可以有多个父母和孩子,但不是循环关系。
主机也可以在多个组,但只会有一个主机的情况下,合并来自多个组的数据。
默认组
有两个默认组:all 和 ungrouped。all 包含每个主机。 ungrouped 包含除了之外没有其他组的所有主机 all。每个主机始终属于至少 2 个组。虽然 all 并且 ungrouped 始终存在,但它们可以是隐含的,而不会出现在组列表中 group_names。

组织主机和组变量
虽然您可以将变量存储在主库存文件中,但存储单独的主机和组变量文件可以帮助您更轻松地跟踪变量值。

主机和组变量可以存储在相对于库存文件的单个文件中(不是目录,它始终是文件)。

这些变量文件采用 YAML 格式。有效的文件扩展名包括“.yml”,“。yaml”,“。json”或没有文件扩展名。如果您是 YAML 的新手,请参阅 YAML 语法。

比方说,您可以将库存文件保存在/etc/ansible/hosts。你有一个名为'foosball'的主持人,它是两个小组的成员:'raleigh'和'webservers'。该主机将在以下位置使用 YAML 文件中的变量:

/etc/ansible/group_vars/raleigh # can optionally end in '.yml', '.yaml', or '.json'
/etc/ansible/group_vars/webservers
/etc/ansible/host_vars/foosball

例如,假设您有按数据中心分组的主机,并且每个数据中心使用一些不同的服务器。'raleigh'组的组文件'/ etc / ansible / group_vars / raleigh'中的数据可能如下所示:


ntp_server: acme.example.org
database_server: storage.example.org
如果这些文件不存在,这是可以的,因为这是一个可选功能。

作为高级用例,您可以创建以组或主机命名的目录,Ansible 将按字典顺序读取这些目录中的所有文件。“raleigh”组的一个例子:

/etc/ansible/group_vars/raleigh/db_settings
/etc/ansible/group_vars/raleigh/cluster_settings
“raleigh”组中的所有主机都将具有这些文件中定义的变量。当单个文件开始太大或者想要在组的变量的一部分上使用 Ansible Vault 时,这对于保持变量有条理非常有用。

提示:group_vars/和 host_vars/目录可以存在于 playbook 目录或 inventory 目录中。如果两个路径都存在,则 playbook 目录中的变量将覆盖 inventory 目录中设置的变量。

提示:该 ansible-playbook 命令默认查找当前工作目录中的 playbooks。其他 Ansible 命令(例如 ansible,ansible-console 等)将只查找 group_vars/和 host_vars/在库存目录中,除非你提供--playbook-dir 的命令行选项。

提示:将库存文件和变量保存在 git 仓库(或其他版本控制)中是跟踪库存和主机变量更改的绝佳方法。

如何合并变量
默认情况下,在运行播放之前将变量合并/展平到特定主机。这使得 Ansible 专注于主机和任务,因此群组在库存和主机匹配之外并不存在。默认情况下,Ansible 会覆盖变量,包括为组和/或主机定义的变量(请参阅 DEFAULT_HASH_BEHAVIOUR)。顺序/优先级是(从最低到最高):

所有组(因为它是所有其他组的“父”)
父母组
儿童组
主办
当合并相同父/子级别的组时,它将按字母顺序完成,并且加载的最后一个组将覆盖先前的组。例如,a_group 将与 b_group 合并,b_group 变量匹配将覆盖 a_group 中的变量。

版本 2.4 中的新功能。

从 Ansible 2.4 版开始,用户可以使用组变量 ansible_group_priority 来更改同级别组的合并顺序(在解析父/子顺序之后)。数字越大,合并越晚,优先级越高。1 如果未设置,此变量默认为。例如:

a_group:
testvar: a
ansible_group_priority: 10
b_group:
testvar: b
在这个例子中,如果两个组具有相同的优先级,结果通常是,但由于我们给出了更高的优先级,结果将是。testvar == ba_grouptestvar == a

注意

ansible_group_priority 只能在库存源中设置,而不能在 group_vars /中设置,因为变量用于加载 group_vars。

使用多个库存来源
作为高级用例,您可以通过从命令行提供多个库存参数或通过配置来同时定位多个库存源(目录,动态库存脚本或库存插件支持的文件) ANSIBLE_INVENTORY。当您希望针对特定操作同时针对正常分离的环境(如分段和生产)时,此功能非常有用。

从命令行定位两个源,如下所示:

ansible-playbook get_logs.yml -i staging -i production
请记住,如果库存中存在可变冲突,则根据变量如何合并和变量优先级中描述的规则来解决它们:我应该在哪里放置变量?。合并顺序由库存源参数的顺序控制。如果[all:vars]在暂存库存中定义,但生产库存定义,则将运行该手册。如果播放剧本,结果将被颠倒 。myvar = 1myvar = 2myvar = 2-i production -i staging

使用目录聚合库存源

您还可以通过在目录下组合多个库存源和源类型来创建库存。这对于组合静态和动态主机以及将它们作为一个库存进行管理非常有用。以下清单将清单插件源,动态清单脚本和文件与静态主机组合在一起:

inventory/
openstack.yml # configure inventory plugin to get hosts from Openstack cloud
dynamic-inventory.py # add additional hosts with dynamic inventory script
static-inventory # add static hosts and groups
group_vars/
all.yml # assign variables to all hosts
您可以像这样定位此库存目录:

ansible-playbook example.yml -i inventory
如果存在可变冲突或组与其他库存源的依赖关系,则控制库存源的合并顺序会很有用。库存根据文件名按字母顺序合并,因此可以通过向文件添加前缀来控制结果:

inventory/
01-openstack.yml # configure inventory plugin to get hosts from Openstack cloud
02-dynamic-inventory.py # add additional hosts with dynamic inventory script
03-static-inventory # add static hosts
group_vars/
all.yml # assign variables to all hosts
如果 01-openstack.yml 定义了组,定义和定义,则将运行该剧本。myvar = 1all02-dynamic-inventory.pymyvar = 203-static-inventorymyvar = 3myvar = 3

有关库存插件和动态库存脚本的更多详细信息,请参阅库存插件和使用动态库存。

连接到主机:行为库存参数
如上所述,设置以下变量可控制 Ansible 与远程主机的交互方式。

主机连接:

注意

Ansible 不会公开一个通道,允许用户和 ssh 进程之间的通信在使用 ssh 连接插件时手动接受密码来解密 ssh 密钥(这是默认设置)。使用的 ssh-agent 强烈建议。

ansible_connection
连接类型到主机。这可以是任何 ansible 连接插件的名称。SSH 协议类型是 smart,ssh 或 paramiko。默认是智能的。基于非 SSH 的类型将在下一节中介绍。
一般所有连接:

ansible_host
要连接的主机的名称,如果与您希望提供给它的别名不同。
ansible_port
连接端口号,如果不是默认值(ssh 为 22)
ansible_user
连接到主机时要使用的用户名
ansible_password
用于向主机进行身份验证的密码(从不以纯文本格式存储此变量;始终使用保管库。请参阅变量和保管库)
特定于 SSH 连接:

ansible_ssh_private_key_file
ssh 使用的私钥文件。如果使用多个密钥并且您不想使用 SSH 代理,则很有用。
ansible_ssh_common_args
此设置始终附加到 sftp,scp 和 ssh 的默认命令行。ProxyCommand 用于为特定主机(或组)配置 a 。
ansible_sftp_extra_args
此设置始终附加到默认的 sftp 命令行。
ansible_scp_extra_args
此设置始终附加到默认 scp 命令行。
ansible_ssh_extra_args
此设置始终附加到默认的 ssh 命令行。
ansible_ssh_pipelining
确定是否使用 SSH 流水线。这可以覆盖中的 pipelining 设置 ansible.cfg。
ansible_ssh_executable(在 2.2 版中添加)
此设置将覆盖使用系统 ssh 的默认行为。这可以覆盖中的 ssh_executable 设置 ansible.cfg。
特权升级(详见 Ansible Privilege Escalation):

ansible_become
等同于 ansible_sudo 或 ansible_su 允许强制权限升级
ansible_become_method
允许设置权限提升方法
ansible_become_user
等同于 ansible_sudo_user 或 ansible_su_user 允许通过权限提升设置您成为的用户
ansible_become_password
等效于 ansible_sudo_password 或 ansible_su_password 允许您设置权限提升密码(永远不要将此变量存储为纯文本;始终使用保管库。请参阅变量和保管库)
ansible_become_exe
等效于 ansible_sudo_exe 或 ansible_su_exe 允许您为所选的升级方法设置可执行文件
ansible_become_flags
等效于 ansible_sudo_flags 或 ansible_su_flags 允许您设置传递给选定升级方法的标志。这也可以 ansible.cfg 在 sudo_flags 选项中全局设置
远程主机环境参数:

ansible_shell_type
目标系统的 shell 类型。除非已将 ansible_shell_executable 设置为非 Bourne(sh)兼容 shell,否则不应使用此设置 。默认情况下,命令使用 sh-style 语法格式化。将此设置为 csh 或 fish 将导致在目标系统上执行的命令遵循这些 shell 的语法。
ansible_python_interpreter
目标主机 python 路径。这对于具有多个 Python 或不位于/ usr / bin / python 的系统(如* BSD)或/ usr / bin / python 不是 2.X 系列 Python 的系统非常有用。我们不使用/ usr / bin / env 机制,因为它需要设置远程用户的路径,并假设 python 可执行文件名为 python,其中可执行文件可能被命名为 python2.6。
ansible _ * _解释
适用于任何东西,如 ruby 或 perl,就像 ansible_python_interpreter 一样。这取代了将在该主机上运行的模块。
版本 2.1 中的新功能。

ansible_shell_executable
这将设置 ansible 控制器将目标机器上使用的壳,将覆盖 executable 在 ansible.cfg 其中默认为 / bin / sh 的。如果无法使用/ bin / sh(即/ bin / sh 未安装在目标计算机上或无法从 sudo 运行),您应该只更改它。
Ansible-INI 主机文件中的示例:

some_host ansible_port=2222 ansible_user=manager
aws_host ansible_ssh_private_key_file=/home/example/.ssh/aws.pem
freebsd_host ansible_python_interpreter=/usr/local/bin/python
ruby_module_host ansible_ruby_interpreter=/usr/bin/ruby.1.9.3
非 SSH 连接类型
如上一节所述,Ansible 通过 SSH 执行 playbooks,但不限于此连接类型。使用主机特定参数 ansible_connection=,可以更改连接类型。以下非基于 SSH 的连接器可用:

本地

此连接器可用于将剧本部署到控制机器本身。

搬运工人

此连接器使用本地 Docker 客户端将 playbook 直接部署到 Docker 容器中。此连接器处理以下参数:

ansible_host
要连接的 Docker 容器的名称。
ansible_user
要在容器内操作的用户名。用户必须存在于容器内。
ansible_become
如果设置为 true 对 become_user 将被用于在容器内运行。
ansible_docker_extra_args
可以是一个包含 Docker 理解的任何其他参数的字符串,它们不是特定于命令的。此参数主要用于配置要使用的远程 Docker 守护程序。
以下是如何立即部署到创建的容器的示例:

- name: create jenkins container
  docker_container:
    docker_host: myserver.net:4243
    name: my_jenkins
    image: jenkins

- name: add container to inventory
  add_host:
    name: my_jenkins
    ansible_connection: docker
    ansible_docker_extra_args: "--tlsverify --tlscacert=/path/to/ca.pem --tlscert=/path/to/client-cert.pem --tlskey=/path/to/client-key.pem -H=tcp://myserver.net:4243"
    ansible_user: jenkins
  changed_when: false

- name: create directory for ssh keys
  delegate_to: my_jenkins
  file:
    path: "/var/jenkins_home/.ssh/jupiter"
    state: directory
  • Ansible
    27 引用 • 3 回帖
  • Linux

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

    915 引用 • 931 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    140 引用 • 441 回帖
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 438 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖 • 1 关注
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖 • 1 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 18 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    22 引用 • 31 回帖 • 3 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 407 回帖 • 524 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 2 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 218 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    40 引用 • 40 回帖
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖
  • 区块链

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

    91 引用 • 751 回帖
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 250 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    228 引用 • 1450 回帖 • 2 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 24 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 4 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    284 引用 • 247 回帖 • 173 关注
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    129 引用 • 793 回帖 • 1 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 906 回帖 • 192 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    5 引用 • 13 回帖 • 1 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 2 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    180 引用 • 400 回帖
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 132 关注
  • JSON

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

    51 引用 • 190 回帖