centos9 stream 下 rabbitmq高可用集群搭建及使用_centos stream 9

最后的话

最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!

资料预览

给大家整理的视频资料:

给大家整理的电子书资料:

如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

exclude all other mechanisms (note: this will disable password-based

authentication even for the management UI!):

auth_mechanisms.1 = EXTERNAL

This pertains to both the rabbitmq-auth-mechanism-ssl plugin and

STOMP ssl_cert_login configurations. See the RabbitMQ STOMP plugin

configuration section later in this file and the README in

https://github.com/rabbitmq/rabbitmq-auth-mechanism-ssl for further

details.

To use the TLS cert’s CN instead of its DN as the username

ssl_cert_login_from = common_name

TLS handshake timeout, in milliseconds.

ssl_handshake_timeout = 5000

Cluster name

cluster_name = dev3.eng.megacorp.local

Password hashing implementation. Will only affect newly

created users. To recalculate hash for an existing user

it’s necessary to update her password.

To use SHA-512, set to rabbit_password_hashing_sha512.

password_hashing_module = rabbit_password_hashing_sha256

When importing definitions exported from versions earlier

than 3.6.0, it is possible to go back to MD5 (only do this

as a temporary measure!) by setting this to rabbit_password_hashing_md5.

password_hashing_module = rabbit_password_hashing_md5

Default User / VHost

====================

On first start RabbitMQ will create a vhost and a user. These

config items control what gets created.

Relevant doc guide: https://rabbitmq.com/access-control.html

default_vhost = /

default_user = guest

default_pass = guest

default_permissions.configure = .*

default_permissions.read = .*

default_permissions.write = .*

Tags for default user

For more details about tags, see the documentation for the

Management Plugin at https://rabbitmq.com/management.html.

default_user_tags.administrator = true

Define other tags like this:

default_user_tags.management = true

default_user_tags.custom_tag = true

Additional network and protocol related configuration

=====================================================

Set the server AMQP 0-9-1 heartbeat timeout in seconds.

RabbitMQ nodes will send heartbeat frames at roughly

the (timeout / 2) interval. Two missed heartbeats from

a client will close its connection.

Values lower than 6 seconds are very likely to produce

false positives and are not recommended.

Related doc guides:

* https://rabbitmq.com/heartbeats.html

* https://rabbitmq.com/networking.html

heartbeat = 60

Set the max permissible size of an AMQP frame (in bytes).

frame_max = 131072

Set the max frame size the server will accept before connection

tuning occurs

initial_frame_max = 4096

Set the max permissible number of channels per connection.

0 means “no limit”.

channel_max = 128

Customising TCP Listener (Socket) Configuration.

Related doc guides:

* https://rabbitmq.com/networking.html

* https://www.erlang.org/doc/man/inet.html#setopts-2

tcp_listen_options.backlog = 128

tcp_listen_options.nodelay = true

tcp_listen_options.exit_on_close = false

tcp_listen_options.keepalive = true

tcp_listen_options.send_timeout = 15000

tcp_listen_options.buffer = 196608

tcp_listen_options.sndbuf = 196608

tcp_listen_options.recbuf = 196608

Resource Limits & Flow Control

==============================

Related doc guide: https://rabbitmq.com/memory.html.

Memory-based Flow Control threshold.

vm_memory_high_watermark.relative = 0.4

Alternatively, we can set a limit (in bytes) of RAM used by the node.

vm_memory_high_watermark.absolute = 1073741824

Or you can set absolute value using memory units (with RabbitMQ 3.6.0+).

Absolute watermark will be ignored if relative is defined!

vm_memory_high_watermark.absolute = 2GB

Supported unit symbols:

k, kiB: kibibytes (2^10 - 1,024 bytes)

M, MiB: mebibytes (2^20 - 1,048,576 bytes)

G, GiB: gibibytes (2^30 - 1,073,741,824 bytes)

kB: kilobytes (10^3 - 1,000 bytes)

MB: megabytes (10^6 - 1,000,000 bytes)

GB: gigabytes (10^9 - 1,000,000,000 bytes)

Fraction of the high watermark limit at which queues start to

page message out to disc in order to free up memory.

For example, when vm_memory_high_watermark is set to 0.4 and this value is set to 0.5,

paging can begin as early as when 20% of total available RAM is used by the node.

Values greater than 1.0 can be dangerous and should be used carefully.

One alternative to this is to use durable queues and publish messages

as persistent (delivery mode = 2). With this combination queues will

move messages to disk much more rapidly.

Another alternative is to configure queues to page all messages (both

persistent and transient) to disk as quickly

as possible, see https://rabbitmq.com/lazy-queues.html.

vm_memory_high_watermark_paging_ratio = 0.5

Selects Erlang VM memory consumption calculation strategy. Can be allocated, rss or legacy (aliased as erlang),

Introduced in 3.6.11. rss is the default as of 3.6.12.

See https://github.com/rabbitmq/rabbitmq-server/issues/1223 and rabbitmq/rabbitmq-common#224 for background.

vm_memory_calculation_strategy = rss

Interval (in milliseconds) at which we perform the check of the memory

levels against the watermarks.

memory_monitor_interval = 2500

The total memory available can be calculated from the OS resources

- default option - or provided as a configuration parameter.

total_memory_available_override_value = 2GB

Set disk free limit (in bytes). Once free disk space reaches this

lower bound, a disk alarm will be set - see the documentation

listed above for more details.

Absolute watermark will be ignored if relative is defined!

disk_free_limit.absolute = 50000

Or you can set it using memory units (same as in vm_memory_high_watermark)

with RabbitMQ 3.6.0+.

disk_free_limit.absolute = 500KB

disk_free_limit.absolute = 50mb

disk_free_limit.absolute = 5GB

Alternatively, we can set a limit relative to total available RAM.

Values lower than 1.0 can be dangerous and should be used carefully.

disk_free_limit.relative = 2.0

Clustering

=====================

cluster_partition_handling = ignore

Pauses all nodes on the minority side of a partition. The cluster

MUST have an odd number of nodes (3, 5, etc)

cluster_partition_handling = pause_minority

pause_if_all_down strategy require additional configuration

cluster_partition_handling = pause_if_all_down

Recover strategy. Can be either ‘autoheal’ or ‘ignore’

cluster_partition_handling.pause_if_all_down.recover = ignore

Node names to check

cluster_partition_handling.pause_if_all_down.nodes.1 = rabbit@localhost

cluster_partition_handling.pause_if_all_down.nodes.2 = hare@localhost

Mirror sync batch size, in messages. Increasing this will speed

up syncing but total batch size in bytes must not exceed 2 GiB.

Available in RabbitMQ 3.6.0 or later.

mirroring_sync_batch_size = 4096

Make clustering happen automatically at startup. Only applied

to nodes that have just been reset or started for the first time.

Relevant doc guide: https://rabbitmq.com//cluster-formation.html

###这里设置集群,所有节点必须保持一致,当然也可以按照前面命令的方式进行设置

cluster_formation.peer_discovery_backend = rabbit_peer_discovery_classic_config

cluster_formation.classic_config.nodes.1 = rabbit1@hostname

cluster_formation.classic_config.nodes.2 = rabbit2@hostname

cluster_formation.classic_config.nodes.3 = rabbit3@hostname

cluster_formation.classic_config.nodes.4 = rabbit4@hostname

DNS-based peer discovery. This backend will list A records

of the configured hostname and perform reverse lookups for

the addresses returned.

cluster_formation.peer_discovery_backend = rabbit_peer_discovery_dns

cluster_formation.dns.hostname = discovery.eng.example.local

This node’s type can be configured. If you are not sure

what node type to use, always use ‘disc’.

cluster_formation.node_type = disc

Interval (in milliseconds) at which we send keepalive messages

to other cluster members. Note that this is not the same thing

as net_ticktime; missed keepalive messages will not cause nodes

to be considered down.

cluster_keepalive_interval = 10000

Statistics Collection

=====================

Statistics collection interval (in milliseconds). Increasing

this will reduce the load on management database.

collect_statistics_interval = 5000

Fine vs. coarse statistics

This value is no longer meant to be configured directly.

See https://www.rabbitmq.com/management.html#fine-stats.

Ra Settings

=====================

raft.segment_max_entries = 65536

raft.wal_max_size_bytes = 1048576

raft.wal_max_batch_size = 4096

raft.snapshot_chunk_size = 1000000

Misc/Advanced Options

=====================

NB: Change these only if you understand what you are doing!

Timeout used when waiting for Mnesia tables in a cluster to

become available.

mnesia_table_loading_retry_timeout = 30000

Retries when waiting for Mnesia tables in the cluster startup. Note that

this setting is not applied to Mnesia upgrades or node deletions.

mnesia_table_loading_retry_limit = 10

Size in bytes below which to embed messages in the queue index.

Related doc guide: https://rabbitmq.com/persistence-conf.html

queue_index_embed_msgs_below = 4096

You can also set this size in memory units

queue_index_embed_msgs_below = 4kb

Whether or not to enable background periodic forced GC runs for all

Erlang processes on the node in “waiting” state.

Disabling background GC may reduce latency for client operations,

keeping it enabled may reduce median RAM usage by the binary heap

(see https://www.erlang-solutions.com/blog/erlang-garbage-collector.html).

Before trying this option, please take a look at the memory

breakdown (https://www.rabbitmq.com/memory-use.html).

background_gc_enabled = false

Target (desired) interval (in milliseconds) at which we run background GC.

The actual interval will vary depending on how long it takes to execute

the operation (can be higher than this interval). Values less than

30000 milliseconds are not recommended.

background_gc_target_interval = 60000

Whether or not to enable proxy protocol support.

Once enabled, clients cannot directly connect to the broker

anymore. They must connect through a load balancer that sends the

proxy protocol header to the broker at connection time.

This setting applies only to AMQP clients, other protocols

like MQTT or STOMP have their own setting to enable proxy protocol.

See the plugins documentation for more information.

proxy_protocol = false

Overriden product name and version.

They are set to “RabbitMQ” and the release version by default.

product.name = RabbitMQ

product.version = 1.2.3

“Message of the day” file.

Its content is used to expand the logged and printed banners.

Default to /etc/rabbitmq/motd on Unix, %APPDATA%\RabbitMQ\motd.txt

on Windows.

motd_file = /etc/rabbitmq/motd

Consumer timeout

If a message delivered to a consumer has not been acknowledge before this timer

triggers the channel will be force closed by the broker. This ensure that

faultly consumers that never ack will not hold on to messages indefinitely.

consumer_timeout = 900000

----------------------------------------------------------------------------

Advanced Erlang Networking/Clustering Options.

Related doc guide: https://rabbitmq.com/clustering.html

----------------------------------------------------------------------------

======================================

Kernel section

======================================

Timeout used to detect peer unavailability, including CLI tools.

Related doc guide: https://www.rabbitmq.com/nettick.html.

net_ticktime = 60

Inter-node communication port range.

The parameters inet_dist_listen_min and inet_dist_listen_max

can be configured in the classic config format only.

Related doc guide: https://www.rabbitmq.com/networking.html#epmd-inet-dist-port-range.

----------------------------------------------------------------------------

RabbitMQ Management Plugin

Related doc guide: https://rabbitmq.com/management.html.

----------------------------------------------------------------------------

=======================================

Management section

=======================================

Preload schema definitions from the following JSON file.

Related doc guide: https://rabbitmq.com/management.html#load-definitions.

management.load_definitions = /path/to/exported/definitions.json

Log all requests to the management HTTP API to a file.

management.http_log_dir = /path/to/access.log

##这里就是web插件的访问地址和端口设置了,变更后访问地址也要跟着变更才能访问到

HTTP listener and embedded Web server settings.

## See https://rabbitmq.com/management.html for details.

management.tcp.port = 15672

management.tcp.ip = 0.0.0.0

management.tcp.shutdown_timeout = 7000

management.tcp.max_keepalive = 120

management.tcp.idle_timeout = 120

management.tcp.inactivity_timeout = 120

management.tcp.request_timeout = 120

management.tcp.compress = true

##https配置,一般内网我们就不配置了,外网可以做url重写

HTTPS listener settings.

See https://rabbitmq.com/management.html and https://rabbitmq.com/ssl.html for details.

management.ssl.port = 15671

management.ssl.cacertfile = /path/to/ca_certificate.pem

management.ssl.certfile = /path/to/server_certificate.pem

management.ssl.keyfile = /path/to/server_key.pem

More TLS options

management.ssl.honor_cipher_order = true

management.ssl.honor_ecc_order = true

These are highly recommended for TLSv1.2 but cannot be used

with TLSv1.3. If TLSv1.3 is enabled, these lines MUST be removed.

management.ssl.client_renegotiation = false

management.ssl.secure_renegotiate = true

Supported TLS versions

management.ssl.versions.1 = tlsv1.2

Cipher suites the server is allowed to use

management.ssl.ciphers.1 = ECDHE-ECDSA-AES256-GCM-SHA384

management.ssl.ciphers.2 = ECDHE-RSA-AES256-GCM-SHA384

management.ssl.ciphers.3 = ECDHE-ECDSA-AES256-SHA384

management.ssl.ciphers.4 = ECDHE-RSA-AES256-SHA384

management.ssl.ciphers.5 = ECDH-ECDSA-AES256-GCM-SHA384

management.ssl.ciphers.6 = ECDH-RSA-AES256-GCM-SHA384

management.ssl.ciphers.7 = ECDH-ECDSA-AES256-SHA384

management.ssl.ciphers.8 = ECDH-RSA-AES256-SHA384

management.ssl.ciphers.9 = DHE-RSA-AES256-GCM-SHA384

URL path prefix for HTTP API and management UI

management.path_prefix = /a-prefix

One of ‘basic’, ‘detailed’ or ‘none’. See

https://rabbitmq.com/management.html#fine-stats for more details.

management.rates_mode = basic

Configure how long aggregated data (such as message rates and queue

lengths) is retained. Please read the plugin’s documentation in

https://rabbitmq.com/management.html#configuration for more

details.

Your can use ‘minute’, ‘hour’ and ‘day’ keys or integer key (in seconds)

management.sample_retention_policies.global.minute = 5

management.sample_retention_policies.global.hour = 60

management.sample_retention_policies.global.day = 1200

management.sample_retention_policies.basic.minute = 5

management.sample_retention_policies.basic.hour = 60

management.sample_retention_policies.detailed.10 = 5

----------------------------------------------------------------------------

RabbitMQ Shovel Plugin

Related doc guide: https://rabbitmq.com/shovel.html

----------------------------------------------------------------------------

See advanced.config.example for a Shovel plugin example

----------------------------------------------------------------------------

RabbitMQ STOMP Plugin

Related doc guide: https://rabbitmq.com/stomp.html

----------------------------------------------------------------------------

=======================================

STOMP section

=======================================

See https://rabbitmq.com/stomp.html for details.

TCP listeners.

stomp.listeners.tcp.1 = 127.0.0.1:61613

stomp.listeners.tcp.2 = ::1:61613

TCP listener settings

stomp.tcp_listen_options.backlog = 2048

stomp.tcp_listen_options.recbuf = 131072

stomp.tcp_listen_options.sndbuf = 131072

stomp.tcp_listen_options.keepalive = true

stomp.tcp_listen_options.nodelay = true

stomp.tcp_listen_options.exit_on_close = true

stomp.tcp_listen_options.send_timeout = 120

Proxy protocol support

stomp.proxy_protocol = false

TLS listeners

See https://rabbitmq.com/stomp.html and https://rabbitmq.com/ssl.html for details.

stomp.listeners.ssl.default = 61614

ssl_options.cacertfile = path/to/cacert.pem

ssl_options.certfile = path/to/cert.pem

ssl_options.keyfile = path/to/key.pem

ssl_options.verify = verify_peer

ssl_options.fail_if_no_peer_cert = true

Number of Erlang processes that will accept connections for the TCP

and TLS listeners.

stomp.num_acceptors.tcp = 10

stomp.num_acceptors.ssl = 1

Additional TLS options

Extract a name from the client’s certificate when using TLS.

stomp.ssl_cert_login = true

Set a default user name and password. This is used as the default login

whenever a CONNECT frame omits the login and passcode headers.

Please note that setting this will allow clients to connect without

authenticating!

stomp.default_user = guest

stomp.default_pass = guest

If a default user is configured, or you have configured use TLS client

certificate based authentication, you can choose to allow clients to

omit the CONNECT frame entirely. If set to true, the client is

automatically connected as the default user or user supplied in the

TLS certificate whenever the first frame sent on a session is not a

CONNECT frame.

stomp.implicit_connect = true

Whether or not to enable proxy protocol support.

Once enabled, clients cannot directly connect to the broker

anymore. They must connect through a load balancer that sends the

proxy protocol header to the broker at connection time.

This setting applies only to STOMP clients, other protocols

like MQTT or AMQP have their own setting to enable proxy protocol.

See the plugins or broker documentation for more information.

stomp.proxy_protocol = false

----------------------------------------------------------------------------

RabbitMQ MQTT Adapter

See https://github.com/rabbitmq/rabbitmq-mqtt/blob/stable/README.md

for details

----------------------------------------------------------------------------

=======================================

MQTT section

=======================================

TCP listener settings.

mqtt.listeners.tcp.1 = 127.0.0.1:61613

mqtt.listeners.tcp.2 = ::1:61613

TCP listener options (as per the broker configuration).

mqtt.tcp_listen_options.backlog = 4096

mqtt.tcp_listen_options.recbuf = 131072

mqtt.tcp_listen_options.sndbuf = 131072

mqtt.tcp_listen_options.keepalive = true

mqtt.tcp_listen_options.nodelay = true

mqtt.tcp_listen_options.exit_on_close = true

mqtt.tcp_listen_options.send_timeout = 120

TLS listener settings

## See https://rabbitmq.com/mqtt.html and https://rabbitmq.com/ssl.html for details.

mqtt.listeners.ssl.default = 8883

ssl_options.cacertfile = /path/to/tls/ca_certificate_bundle.pem

ssl_options.certfile = /path/to/tls/server_certificate.pem

ssl_options.keyfile = /path/to/tls/server_key.pem

ssl_options.verify = verify_peer

ssl_options.fail_if_no_peer_cert = true

Number of Erlang processes that will accept connections for the TCP

and TLS listeners.

mqtt.num_acceptors.tcp = 10

mqtt.num_acceptors.ssl = 10

Whether or not to enable proxy protocol support.

Once enabled, clients cannot directly connect to the broker

anymore. They must connect through a load balancer that sends the

proxy protocol header to the broker at connection time.

This setting applies only to STOMP clients, other protocols

like STOMP or AMQP have their own setting to enable proxy protocol.

See the plugins or broker documentation for more information.

mqtt.proxy_protocol = false

Set the default user name and password used for anonymous connections (when client

provides no credentials). Anonymous connections are highly discouraged!

mqtt.default_user = guest

mqtt.default_pass = guest

Enable anonymous connections. If this is set to false, clients MUST provide

credentials in order to connect. See also the mqtt.default_user/mqtt.default_pass

keys. Anonymous connections are highly discouraged!

mqtt.allow_anonymous = true

If you have multiple vhosts, specify the one to which the

adapter connects.

mqtt.vhost = /

Specify the exchange to which messages from MQTT clients are published.

mqtt.exchange = amq.topic

Specify TTL (time to live) to control the lifetime of non-clean sessions.

mqtt.subscription_ttl = 1800000

Set the prefetch count (governing the maximum number of unacknowledged

messages that will be delivered).

mqtt.prefetch = 10

----------------------------------------------------------------------------

RabbitMQ AMQP 1.0 Support

See https://github.com/rabbitmq/rabbitmq-amqp1.0/blob/stable/README.md.

----------------------------------------------------------------------------

=======================================

AMQP 1.0 section

=======================================

Connections that are not authenticated with SASL will connect as this

account. See the README for more information.

Please note that setting this will allow clients to connect without

authenticating!

amqp1_0.default_user = guest

Enable protocol strict mode. See the README for more information.

amqp1_0.protocol_strict_mode = false

Logging settings.

See https://rabbitmq.com/logging.html for details.

Log directory, taken from the RABBITMQ_LOG_BASE env variable by default.

log.dir = /var/log/rabbitmq

Logging to file. Can be false or a filename.

Default:

log.file = rabbit.log

To disable logging to a file

log.file = false

Log level for file logging

log.file.level = info

File rotation config. No rotation by default.

DO NOT SET rotation date to ‘’. Leave the value unset if “” is the desired value

log.file.rotation.date = $D0

log.file.rotation.size = 0

Logging to console (can be true or false)

log.console = false

Log level for console logging

log.console.level = info

Logging to the amq.rabbitmq.log exchange (can be true or false)

log.exchange = false

Log level to use when logging to the amq.rabbitmq.log exchange

log.exchange.level = info

----------------------------------------------------------------------------

RabbitMQ LDAP Plugin

Related doc guide: https://rabbitmq.com/ldap.html.

----------------------------------------------------------------------------

=======================================

LDAP section

=======================================

Connecting to the LDAP server(s)

================================

Specify servers to bind to. You must set this in order for the plugin

to work properly.

auth_ldap.servers.1 = your-server-name-goes-here

You can define multiple servers

auth_ldap.servers.2 = your-other-server

Connect to the LDAP server using TLS

auth_ldap.use_ssl = false

Specify the LDAP port to connect to

auth_ldap.port = 389

LDAP connection timeout, in milliseconds or ‘infinity’

auth_ldap.timeout = infinity

Or number

auth_ldap.timeout = 500

Enable logging of LDAP queries.

One of

- false (no logging is performed)

- true (verbose logging of the logic used by the plugin)

- network (as true, but additionally logs LDAP network traffic)

Defaults to false.

auth_ldap.log = false

Also can be true or network

auth_ldap.log = true

auth_ldap.log = network

Authentication

==============

Pattern to convert the username given through AMQP to a DN before

binding

auth_ldap.user_dn_pattern = cn=${username},ou=People,dc=example,dc=com

Alternatively, you can convert a username to a Distinguished

Name via an LDAP lookup after binding. See the documentation for

full details.

When converting a username to a dn via a lookup, set these to

the name of the attribute that represents the user name, and the

base DN for the lookup query.

auth_ldap.dn_lookup_attribute = userPrincipalName

auth_ldap.dn_lookup_base = DC=gopivotal,DC=com

Controls how to bind for authorisation queries and also to

retrieve the details of users logging in without presenting a

password (e.g., SASL EXTERNAL).

One of

- as_user (to bind as the authenticated user - requires a password)

- anon (to bind anonymously)

- {UserDN, Password} (to bind with a specified user name and password)

Defaults to ‘as_user’.

auth_ldap.other_bind = as_user

Or can be more complex:

auth_ldap.other_bind.user_dn = User

auth_ldap.other_bind.password = Password

If user_dn and password defined - other options is ignored.

-----------------------------

Too complex section of LDAP

-----------------------------

Authorisation

=============

The LDAP plugin can perform a variety of queries against your

LDAP server to determine questions of authorisation.

Related doc guide: https://rabbitmq.com/ldap.html#authorisation.

Following configuration should be defined in advanced.config file

DO NOT UNCOMMENT THESE LINES!

Set the query to use when determining vhost access

{vhost_access_query, {in_group,

“ou=${vhost}-users,ou=vhosts,dc=example,dc=com”}},

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

Too complex section of LDAP

-----------------------------

Authorisation

=============

The LDAP plugin can perform a variety of queries against your

LDAP server to determine questions of authorisation.

Related doc guide: https://rabbitmq.com/ldap.html#authorisation.

Following configuration should be defined in advanced.config file

DO NOT UNCOMMENT THESE LINES!

Set the query to use when determining vhost access

{vhost_access_query, {in_group,

“ou=${vhost}-users,ou=vhosts,dc=example,dc=com”}},

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 16
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值