ZincSearch一款 Elasticsearch 的轻量级替代品
本文最后更新于 326 天前, 如有失效请评论区留言.
支持全文索引的搜索引擎,是 Elasticsearch 的轻量级替代品
优点
仅列出我目前在用的功能特性
- 提供全文索引功能
- Elasticsearch API 完全兼容,用于提取数据(单/批量 API)
- 开箱即用的身份验证
- 使用 Go/Vue 开发,支持多平台部署简单,提供可视化 UI
- 聚合支持
项目
部署
docker
mkdir -p /data/es
docker run -v /data/es:/data -e ZINC_DATA_PATH="/data" -p 4080:4080
-e ZINC_FIRST_ADMIN_USER=ysicing -e ZINC_FIRST_ADMIN_PASSWORD=ysicingme
--name zincsearch ccr.ccs.tencentyun.com/k7scn/zincsearch
k8s 部署
zincsearch.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
labels:
k8s.ysicing.me/name: zincsearch
name: zincsearch
spec:
storageClassName: lh
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 20Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
k8s.ysicing.me/name: zincsearch
name: zincsearch
spec:
replicas: 1
selector:
matchLabels:
k8s.ysicing.me/name: zincsearch
strategy:
type: Recreate
template:
metadata:
labels:
k8s.ysicing.me/name: zincsearch
spec:
nodeSelector:
node-role.kubernetes.io/china: "true"
containers:
- image: ccr.ccs.tencentyun.com/k7scn/zincsearch
imagePullPolicy: Always
env:
- name: ZINC_FIRST_ADMIN_USER
value: ysicing
- name: ZINC_DATA_PATH
value: /data
- name: ZINC_FIRST_ADMIN_PASSWORD
value: ysicingme
name: zincsearch
resources:
limits:
cpu: 1024m
memory: 2048Mi
requests:
cpu: 32m
memory: 50Mi
volumeMounts:
- mountPath: /data
name: zincsearch
restartPolicy: Always
initContainers:
- name: volume-permissions
image: docker.io/bitnami/os-shell:11-debian-11-r92
imagePullPolicy: "IfNotPresent"
command:
- /bin/bash
args:
- -ec
- |
mkdir -p /data
chmod a+rwx /data
securityContext:
runAsUser: 0
resources:
limits: {}
requests: {}
volumeMounts:
- name: zincsearch
mountPath: /data
volumes:
- name: zincsearch
persistentVolumeClaim:
claimName: zincsearch
---
apiVersion: v1
kind: Service
metadata:
labels:
k8s.ysicing.me/name: zincsearch
name: zincsearch
spec:
ports:
- name: http
port: 4080
protocol: TCP
targetPort: 4080
selector:
k8s.ysicing.me/name: zincsearch
type: ClusterIP
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
labels:
k8s.ysicing.me/name: zincsearch
name: zincsearch
spec:
rules:
- host: es.i.ysicing.net
http:
paths:
- backend:
service:
name: zincsearch
port:
name: http
path: /
pathType: ImplementationSpecific
将上面的 yaml 文件保存为 zincsearch.yaml
, 需要将 es.i.ysicing.net
改成自己的域名哈
生效
kubectl apply -f zincsearch.yaml
收集日志
我使用的是 sidecar 方式收集的,其他方式也可以。
apiVersion: apps.kruise.io/v1alpha1
kind: SidecarSet
metadata:
name: nginx-ingress-filebeat
spec:
namespace: kube-system
updateStrategy:
type: RollingUpdate
partition: 0
selector:
matchLabels:
app.kubernetes.io/instance: nginx-ingress-controller
containers:
- name: filebeat
image: hub.i.ysicing.net/devops/filebeat:202312
volumeMounts:
- name: log-volume
mountPath: /var/log/nginxweb
- name: filebeat
mountPath: /usr/share/filebeat/data
volumes:
- emptyDir: {}
name: log-volume
- emptyDir: {}
name: filebeat
不提供 hub.i.ysicing.net/devops/filebeat:202312
镜像哈,因为默认有我的凭证,这里给出构建的镜像
filebeat 构建
Dockerfile 如下, filebeat
这个版本是 OK,不同版本下可能适配有问题,如果有问题可以去 zincsearch 社区反馈
FROM h2.ysicing.net/ysicing/debian as builder
WORKDIR /root
RUN curl -L -O https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-8.2.3-linux-x86_64.tar.gz \
&& tar xzvf filebeat-8.2.3-linux-x86_64.tar.gz
FROM h2.ysicing.net/ysicing/debian
WORKDIR /root
COPY --from=builder /root/filebeat-8.2.3-linux-x86_64/filebeat /usr/bin/filebeat
COPY --from=builder /root/filebeat-8.2.3-linux-x86_64/module /root/config/module
COPY --from=builder /root/filebeat-8.2.3-linux-x86_64/modules.d /root/config/modules.d
COPY filebeat.yml /root/filebeat.yml
CMD ["/usr/bin/filebeat","-e","-c","/root/filebeat.yml", "--path.data", "/usr/share/filebeat/data", "--path.config", "/root/config"]
filebeat 配置如下:
setup.ilm.enabled: false
setup.template.name: "nginx-ingress"
setup.template.pattern: "nginx-ingress-*"
setup.template.settings:
index.number_of_shards: 1
index.number_of_replicas: 0
index.refresh_interval: 5s
filebeat.inputs:
- type: log
enabled: true
paths:
- /var/log/nginxweb/*.log
json.keys_under_root: true
json.add_error_key: true
json.message_key: log
json.expand_keys: true
fields:
app: nginx-ingress
filebeat.config.modules:
path: ${path.config}/modules.d/*.yml
reload.enabled: true
processors:
- add_host_metadata:
when.not.contains.tags: forwarded
# - add_cloud_metadata: ~
# - add_docker_metadata: ~
- add_kubernetes_metadata: ~
fields_under_root: true
output.elasticsearch:
hosts: ["zincsearch.default.svc:4080"]
protocol: "http"
path: "/es/"
username: "ysicing"
password: "ysicingme"
index: "nginx-ingress-%{+yyyy.MM.dd}"
根据上面的操作,直接构建出镜像就可以啦。
总结
反正比 ES 使用简单,基本功能也能满足需求。如果没有其他特殊需求,可以替代。