| Field | Value |
|---|---|
| Connection Name | Elasticsearch Connection |
| Summary | Manages REST-based Elasticsearch cluster access and log index automation |
| Category | Database |
| Protocol | REST |
| Supported Environments | Development, Test, Production |
Overview
What is its Purpose?
Connection transmits log, metric, and search data from Integration Flow or Connector steps to a central Elasticsearch cluster. Manages REST requests with high availability through multiple host (HTTP/HTTPS) definitions. Standardizes cluster governance through Index Template and Index Lifecycle Policy (ILM) automation. Triggers maintenance tasks such as rollover, template creation, and policy synchronization with a single click.Working Principle
Connection Initiation: When an Elasticsearch Connection is requested from within an Integration Flow or Connector, the system reads the configured connection parameters. Connection Pool Management: The HTTP client selects an appropriate connection from the pool or opens a new one based onioThreads, maxConnectionPerHost, and maxConnectionTotal values.
Authentication: When Basic Authentication is provided, username/password are sent; otherwise, anonymous access or IP-based security is used.
Data Communication: JSON-bodied CRUD requests are sent to REST endpoints over HTTP/HTTPS; socket settings (keep-alive, reuse) ensure transmission continuity.
Connection Management: When the operation completes, the connection returns to the pool, and open sockets close when keep-alive periods expire.
Error Management: On connection error, timeout, or authentication error, Apinizer Message Service generates notifications; details are shown in the deployment result dialog.
Usage Areas
- Writing Gateway logs to central Elasticsearch indices
- Accessing read-only clusters for search/reporting purposes
- Managing high-volume log clusters requiring ILM and template automation
- Routing traffic to disaster recovery or geo-redundant Elasticsearch clusters
Technical Features and Capabilities
Basic Features
Multiple Host Management: Provides load distribution among cluster nodes through HTTP/HTTPS scheme, host, and port combinations. Index Template Automation: Shard/replica counts and refresh interval values are managed through the UI. Administrative Operations: When theAdministrate option is enabled, Index Template, ILM Policy creation, and rollover trigger buttons become active.
Environment-Based Configuration: Ability to define separate connection parameters for each environment (Development, Test, Production).
Enable/Disable Control: Activating or deactivating the connection (enable/disable toggle). In passive state, the connection cannot be used but its configuration is preserved.
Advanced Features
Index Lifecycle Editor: Age, size, and replication thresholds for Hot/Warm/Cold/Delete phases are controlled through a modal. TLS Certificate Flexibility: SSL/TLS communication is secured by uploading PKCS#12 or PEM-based CA/keystore files. Read/Write Mode: InREAD_WRITE mode, administrative operations are active; in READ mode, only queries are performed.
Connection Test Feature: Ability to validate connection parameters before saving using the “Test Connection” button.
Export/Import Feature: Exporting connection configuration as a ZIP file. Importing to different environments (Development, Test, Production). Version control and backup capability.
Connection Monitoring: Monitoring connection health, pool status, and performance metrics.
Connection Parameters
Required Parameters
| Parameter | Description | Example Value | Notes |
|---|---|---|---|
| Name | Connection name (must be unique) | Production_ElasticLog | Cannot start with a space, special characters should not be used |
| Index Name | Index name where logs will be written | apinizer-log-apiproxy-default | Automatically created when Administrate is enabled; conflicts are checked |
| Elastic Host (Host & Port) | Scheme/host/port for each host | HTTPS : es-prod-01 : 9243 | At least one host is required; host and port fields cannot be left empty |
| Connection Timeout (ms) | Wait time for connection establishment | 5000 | Default 5000; negative values are not accepted |
| IO Threads | HTTP client thread count | 32 | Minimum 1; should be increased for high traffic |
| Max Connection Per Host | Concurrent request limit per host | 128 | Minimum 1 |
| Max Connection Total | Total connection pool limit | 256 | Minimum 1 |
| Connection Type | READ_WRITE or READ mode | READ_WRITE | If READ is selected, administrate is disabled |
Optional Parameters
| Parameter | Description | Default Value | Recommended Value |
|---|---|---|---|
| Description | Connection purpose description | Empty | Short text containing operational information |
| Authenticate | Basic Authentication on/off | false | true based on requirements in Production |
| Elastic Username | Username | Empty | Required if Authentication is active |
| Elastic Password | Password | Empty | Should be entered through secret manager |
| Administrate | Template/ILM management | true (READ_WRITE) | Can be closed if external team manages |
| Socket Keep Alive | TCP keep-alive | true | Keep enabled if network devices drop idle connections |
| Socket Reuse Address | Address reuse | true | Keep enabled in multi-worker deployments |
| Disable Hostname Verification | TLS hostname verification | true | Change to false in Production |
Timeout and Connection Pool Parameters
| Parameter | Description | Default | Min | Max | Unit |
|---|---|---|---|---|---|
| Connection Timeout | Maximum wait time for connection establishment | 5000 | 1000 | 60000 | milliseconds |
| Request Timeout | Wait time for Elasticsearch response | 60000 | 1000 | 120000 | milliseconds |
| Pool Size | Maximum number of connections in the connection pool | 256 | 1 | 2000 | count |
| Socket Idle Timeout | Timeout for closing idle connections | 30000 | 1000 | 600000 | milliseconds |
Usage Scenarios
| Scenario | Situation | Solution (Connection Configuration) | Expected Behavior / Result |
|---|---|---|---|
| High-Volume Log Writing | Millions of log entries per minute | READ_WRITE, administrate enabled, ioThreads=64, maxConnectionTotal=512 | ILM automatically performs rollover, no write queue forms |
| Reporting Cluster | Read-only queries | READ, administrate disabled, authentication=true | Cluster only receives queries, management operations are blocked |
| Multiple Host Failover | Two data centers | Two HTTPS hosts, encrypt communication + PKCS#12 CA | Traffic automatically routes to healthy host |
| Schema Update | New fields added | Update template name and shard/replica, then run “Create Index Template” | New indices open with current schema |
| Data Retention Policy | Logs older than 90 days will be deleted | ILM delete phase active, minAgeOfDelete=90 | Old indices are automatically cleaned |
| Secure Tunnel | TLS required, internal CA | Encrypt communication enabled, CA_IN_PEM_FILE uploaded | Secure connection established with certificates |
Connection Configuration
In this step, users can create a new connection or configure existing connection parameters to set connection rules. Defined parameters directly affect how the connection works and become available for use in Integration Flow or Connector steps.Creating a New Elasticsearch Connection

Configuration Steps
1
Navigate to Creation Page
- Go to Connection → Elasticsearch from the left menu.
- Click the [+ Create] button in the top right.
- The new Elasticsearch Connection creation form opens.
2
Enter Basic Information
Enable Status (Active Status) Setting:
- Find the Enable Status toggle at the top of the form.
- Set the toggle to Active position (defaults to active).
- If you want to make the connection passive, set the toggle to Passive position.
- Passive connections cannot be used in Integration Flows but their configurations are preserved.
- Enter a unique connection name in the Name field.
- Name examples:
`Production_ElasticLog`,`Test_ElasticConnection`,`Dev_ElasticSearch` - Naming rules:
- Cannot start with a space
- Special characters should not be used (recommended: letters, numbers, underscore)
- Maximum 255 characters
- The system automatically checks as you type:
- Green checkmark: Name is available
- Red X mark: Name already exists, choose a different name
- Enter text describing the connection’s purpose in the Description field.
- Example descriptions:
- “Writes Gateway logs to production cluster”
- “Production environment Elasticsearch connection”
- “Dummy Elasticsearch connection for test environment”
- Maximum 1000 character limit.
- This field can be left empty.
3
Environment Selection
- Find the Environment dropdown menu.
- Open the dropdown menu and select one of the following options:
- Development: For development environment
- Test: For test environment
- Production: For production environment
- Different connection parameters can be defined for each environment.
- Environment selection determines in which environment the connection will be active.
- Connections with the same name can be created separately for different environments.
4
Elasticsearch Host Parameters
Scheme Selection:
- Select Scheme for each host: HTTP or HTTPS
- When HTTPS is selected, Encrypt Communication automatically opens.
- Enter the Elasticsearch node’s address in the Host field.
- Enter the port number in the Port field (default: 9200).
- Host format:
- FQDN (Fully Qualified Domain Name):
`es-prod-01.company.com` - IP address:
`192.168.1.100` - Add multiple hosts to backup cluster access.
- At least one host is required.
- Select from the Connection Type dropdown menu:
- READ_WRITE: For read and write operations (administrative operations active)
- READ: For read-only operations (administrate disabled)
- Connection type selection determines administrate behavior.
5
Index Template and ILM Configuration
Index Name - Required:
- Enter the index name where logs will be written in the Index Name field.
- Example:
`apinizer-log-apiproxy-default` - Automatically created when Administrate is enabled; conflicts are checked.
- Find the Administrate toggle.
- Set the toggle to Active position for template and ILM management.
- When Administrate is active, the following fields become visible:
- Template name
- Shard count
- Replica count
- Refresh interval
- Click the Edit ILM Policy button.
- Set hot/warm/cold/delete phase thresholds in the opened modal.
- Verify that the policy name is unique.
- Check the policy name before the first deployment.
6
Timeout and Connection Pool Settings
Connection Timeout:
- Enter the wait time for connection establishment in the Connection Timeout (ms) field.
- Default: 5000 milliseconds
- Minimum: 1000, Maximum: 60000 milliseconds
- Enter the HTTP client thread count in the IO Threads field.
- Minimum: 1
- Should be increased for high traffic (e.g., 64)
- Enter the concurrent request limit per host in the Max Connection Per Host field.
- Minimum: 1
- Recommended: 128
- Enter the total connection pool limit in the Max Connection Total field.
- Minimum: 1, Maximum: 2000
- Recommended: 256
- Find the Socket Keep Alive toggle (default: active).
- Find the Socket Reuse Address toggle (default: active).
- Keep keep-alive enabled if network devices drop idle connections.
- Keep reuse address enabled in multi-worker deployments.
7
Security and Authentication Settings
Authentication Setting:
- Find the Authenticate toggle.
- If your Elasticsearch cluster requires authentication, set the toggle to Active position.
- Most production environments require authentication.
- When the Authenticate toggle is active, the Elastic Username field becomes visible.
- Enter the Elasticsearch username.
- Enter the password in the Elastic Password field.
- The password will appear masked for security reasons.
- Use of secret manager is recommended for sensitive information.
- When at least one host has HTTPS selected, the Encrypt Communication section becomes visible.
- Select TLS type:
- PKCS#12 CA: CA file in PKCS#12 format
- PEM CA: CA file in PEM format
- PKCS#12 cert+key: Certificate and key file in PKCS#12 format
- Upload the required files.
- Forms with missing files will error and not allow saving.
- Find the Disable Hostname Verification toggle.
- Change to false in Production (default: true).
- Can be left as true in test environment.
8
Test Connection
- Find the [Test Connection] button at the bottom of the form or in the top right corner.
- Click the button.
- The system tests the connection parameters:
- Connection is established to Elasticsearch cluster
- Authentication is performed (if Authentication is active)
- TLS handshake is performed (if Encrypt Communication is active)
- Cluster health is checked
- Test result:
- Successful: Green confirmation message is displayed, such as “Connection test successful”
- Failed: Red error message is displayed, error details are shown
- In case of error:
- Read the error message
- Check relevant parameters (Host, Port, Username, Password)
- Check firewall and network settings
- Check Elasticsearch cluster health
- Fix parameters and test again until test is successful.
9
Save and Deploy
- Ensure all required fields are filled.
- Verify that test connection is successful (recommended).
- Click the [Save and Deploy] button in the top right corner of the form.
- The system saves the connection and deploys it to the selected environment.
- After successful save:
- You are redirected to the connection list page
- New connection appears in the list
- Connection becomes Enabled
- Becomes available for use in Integration Flow and Connector steps
- Name field is unique and valid
- At least one Host and Port fields are filled
- Index Name is filled
- Connection Type is selected
- If Authentication is active, Username and Password are filled
- Environment is selected
- Test Connection is successful (recommended)
- All required fields are filled
- Connection is successfully created and saved
- Becomes active in the selected environment
- Connection selection can be made in Integration Flow and Connector steps
- Appears in connection list and can be managed
Deleting Connection
| Section / Step | Description and Functions |
|---|---|
| Delete Operation | Select Delete from the ⋮ menu at the end of the row or click the [Delete] button on the connection detail page |
| Delete Tips | Check Before Deleting: May be in use in Integration Flow or Connector steps. If necessary, assign an alternative connection. Take a backup with Export before deleting |
| Alternative: Deactivate | Instead of deleting, use the Disable option. Connection becomes passive but is not deleted. Can be reactivated when needed |
Exporting/Importing Connection
In this step, users can export (export) existing connections for backup, moving to different environments, or sharing purposes, or import (import) a previously exported connection again. This operation is used to maintain data integrity in version control, transitions between test and production environments, or inter-team sharing processes.| Section / Step | Description and Functions |
|---|---|
| Export | Method 1: Select ⋮ → Export from the action menu. ZIP file is automatically downloaded. Method 2: Click the [Export] button on the connection detail page. ZIP file is downloaded |
| File Format | Format: Date-connection-ConnectionName-export.zip. Example: `13 Nov 2025-connection-Production_ElasticLog-export.zip` |
| ZIP Contents | Connection JSON file, Metadata information, Dependency information (e.g., certificates, key store) |
| Usage Areas | Backup, Moving between environments (Test → Prod), Versioning, Team or project-based sharing |
| Import | Click the [Import Elasticsearch] button on the main list. Select the downloaded ZIP file. System checks: Is format valid? Is there a name conflict? Are dependencies available? Then click the [Import] button |
| Import Scenarios | Scenario 1: Name Conflict → Overwrite the old connection or create with a new name. Scenario 2: Missing Dependencies → Create missing certificates or key stores first or remove them during import |
Connection Usage Areas
In this step, users can use the Elasticsearch connection they created in different components of the system. Connections are used by being selected in Integration Flow, Connector steps, or Scheduled Jobs.| Usage Location | Description and Functions |
|---|---|
| Connection Creation and Activation | Steps: 1. Create the connection. 2. Verify the connection with Test Connection. 3. Save and activate with Save and Deploy. 4. Ensure the connection is in Enabled status |
| Usage in Integration / Connector Steps | Connection is selected in steps requiring communication with external systems such as message queues (queue), topics, email, FTP/SFTP, LDAP, or similar. Examples: steps like “Send Message”, “Consume Message”, “Upload File”, “Read Directory”. Connection selection is made from the Connection field in these steps’ configuration |
| Scheduled Job Usage | In scheduled tasks (e.g., sending messages at certain intervals, file processing, etc.), connection is selected to access external systems. When connection changes, job behavior is updated accordingly |
| Test Usage | Connection accuracy can be checked independently of Integration Flow using the Connection Test feature. This test is critical in the debugging process |
Best Practices
Things to Do and Best Practices
| Category | Description / Recommendations |
|---|---|
| Index Naming | Bad: index1. Good: log-prod. Best: `prod-apiproxy-log-{yyyy.MM.dd}` |
| ILM Policies | Bad: Not changing defaults. Good: Setting max size according to daily data volume. Best: Setting both size and age thresholds and regularly using the rollover button |
| TLS Certificate Management | Bad: Sharing the same certificate across all environments. Good: Loading environment-based certificates. Best: Planning certificate rotation with automation and setting expiration alarms |
| Connection Type Selection | Bad: Giving READ_WRITE to read-only cluster. Good: Making selection according to permission requirements. Best: Updating connection type if cluster role changes |
| Environment Management | Bad: Using the same connection parameters in all environments. Good: Creating separate connections for each environment. Best: Managing all environments in a single connection using the Environment option, only changing environment when transitioning between environments |
| Connection Test | Bad: Saving and deploying connection without testing. Good: Verifying with Test Connection before saving. Best: Testing after every parameter change, performing full integration test in test environment before going to production |
Security Best Practices
| Security Area | Description / Warnings |
|---|---|
| Access Segmentation | Create separate connections and RBAC users for production cluster; do not share access tokens |
| File Uploads | Do not put PKCS#12/PEM files in version control; upload through secret storage |
| Hostname Verification | Disable Hostname Verification should only be used for testing; recommended to leave as false in production |
| Credential Management | Store sensitive information such as usernames and passwords using environment variables or secret manager. Do not hardcode credentials in code or configuration files. Update passwords periodically |
| SSL/TLS Usage | Always enable SSL/TLS in production environment. Use self-signed certificates only in development environment. Track certificate expiration dates and renew them on time |
| Access Control | Allow only authorized users to change connection configuration. Store connection change logs. Apply change approval process for critical connections |
Things to Avoid
| Category | Description / Warnings |
|---|---|
| Index Name Reuse | Why to avoid: Creates conflicts in indices sharing the same template. Alternative: Use project-based prefix |
| Missing Host Definition | Why to avoid: All flows stop if single host fails. Alternative: Enter at least two hosts, monitor health check |
| Unallowed TLS Types | Why to avoid: Wrong file type leads to handshake failure. Alternative: Use certificate package appropriate for HTTPS selection |
| Using Production Connection in Test Environment | Why to avoid: Test data may be written to production system, real users may be affected, security risk occurs. Alternative: Create separate connections for each environment, use environment parameter, separate connection names by adding prefix according to environment (Test_, Prod_) |
| Very Low Timeout Values | Why to avoid: Connection continuously times out in network delays, Integration steps fail. Alternative: Set timeout values according to real usage scenarios, measure network latency and set timeouts accordingly |
| Not Using Connection Pool | Why to avoid: New connection opens with each request, performance decreases, resource consumption increases, target system load increases. Alternative: Enable connection pool, set pool size according to traffic volume, set up pool monitoring |
Performance Tips
| Criterion | Recommendation / Effect |
|---|---|
| Shard/Replica Planning | Recommendation: Determine shard count according to daily record volume, set replica count according to cluster capacity. Effect: Search performance increases, disk usage is balanced |
| ILM Phase Durations | Recommendation: Reduce storage costs by keeping hot phase short and cold phase long. Effect: Unnecessary data is not kept on expensive nodes |
| Thread Pool Monitoring | Recommendation: Track bulk/search queue lengths from monitor screen; if thresholds are exceeded, increase ioThreads/pool values. Effect: Number of requests waiting in queue decreases |
| Connection Pool Optimization | Recommendation: Set pool size according to peak traffic (recommended: concurrent request count × 1.5), set idle connection timeouts, perform pool health check. Effect: Connection opening cost decreases by 80%, response times decrease, resource usage is optimized |
| Timeout Values Optimization | Recommendation: Measure real network latency, set timeout values accordingly, avoid very low or very high timeouts. Effect: Unnecessary waits are prevented, fast fail-over is provided, user experience improves |
| Connection Monitoring | Recommendation: Monitor connection pool usage, track timeout rates, perform connection health check, set up alerting. Effect: Problems are proactively detected, performance bottlenecks are identified early, downtime decreases |
Troubleshooting
| Problem | Possible Causes | Solution Steps |
|---|---|---|
| Index Template Not Created | Administrate disabled, Template name conflicts, Elasticsearch user permission insufficient | 1. Enable Administrate. 2. Change template name. 3. Grant manage_index_templates permission to user |
| ILM Policy Not Saving | Policy name exists, Hot phase disabled, UI modal not closed | 1. Make policy name unique. 2. Enable Hot phase. 3. Click Save in modal and try again |
| Connection Timeout | Network delay, Target system responding slowly, Timeout value too low | 1. Check network connectivity. 2. Check target system health. 3. Increase timeout values. 4. Review connection logs |
| Authentication Failed | Wrong username/password, Expired credentials, Permission problem | 1. Verify credentials. 2. Check that user is active in target system. 3. Check that necessary permissions are granted. 4. Check SSL/TLS certificates |
| Pool Exhausted | Pool size too low, Connection leak exists, Traffic too high | 1. Increase pool size. 2. Check that connections are properly closed. 3. Set idle connection timeouts. 4. Monitor connection usage metrics |
| Connection Test Successful But Integration Flow Errors | Different connection may be selected in Integration/Connector step, Step may be misconfigured, Flow/Job may not be redeployed | 1. Check that connection’s enable toggle is active. 2. Verify that correct connection is selected in Integration Flow. 3. Redeploy connection. 4. Redeploy Integration Flow or Job. 5. Check Gateway logs |
Frequently Asked Questions (FAQ)
| Category | Question (Q) | Answer (A) |
|---|---|---|
| General | Can I use a single connection for two different environments? | Thanks to the environment dropdown, Development/Test/Production values can be kept within the same connection; however, it is safer to create separate connections for access policies |
| General | What does the Rollover button do? | Manually rollovers the active index of the specified connection; can be used in emergencies before ILM threshold is reached |
| Technical | Can Encrypt Communication be opened without HTTPS host? | No, TLS fields are not visible unless at least one host has HTTPS selected; update host scheme for security requirements |
| Technical | Does ILM policy apply to all indices? | Indices created with the same template and policy name are affected; if you use different names, manual assignment is required |
| Usage | What do thread pool data in Monitor screen show? | Shows bulk/search/ingest queue lengths, rejection counts, and active thread count of Elasticsearch nodes; used for performance tuning |
| General | Can I use the same connection in multiple Integration Flows? | Yes, the same connection can be used in multiple Integration Flow or Connector steps. This provides central management and guarantees configuration consistency. However, changes made to the connection will affect all usage locations, so care should be taken |
| Technical | Is using connection pool mandatory? | Using connection pool is not mandatory but strongly recommended in high-traffic systems. Reusing existing connections instead of opening new ones with each request significantly increases performance |
| Usage | Should I create different connections for Test and Production? | Yes, it is recommended to create separate connections for each environment. Alternatively, you can manage all environments within a single connection using the environment parameter. This approach provides easier management and less error risk |
| Technical | Test Connection is successful but not working in Integration Flow, why? | Several reasons may exist: 1) Connection enable toggle may be passive, 2) Different connection may be selected in Integration step, 3) Connection may not be deployed, 4) Integration Flow may not be redeployed yet |

