Ana içeriğe atla
Last Updated: November 15, 2025 Target Audience: System Administrators, Backend Developers, DevOps Engineers, Integration Specialists
FieldValue
Connection NameElasticsearch Connection
SummaryManages REST-based Elasticsearch cluster access and log index automation
CategoryDatabase
ProtocolREST
Supported EnvironmentsDevelopment, 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 on ioThreads, 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 the Administrate 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: In READ_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

ParameterDescriptionExample ValueNotes
NameConnection name (must be unique)Production_ElasticLogCannot start with a space, special characters should not be used
Index NameIndex name where logs will be writtenapinizer-log-apiproxy-defaultAutomatically created when Administrate is enabled; conflicts are checked
Elastic Host (Host & Port)Scheme/host/port for each hostHTTPS : es-prod-01 : 9243At least one host is required; host and port fields cannot be left empty
Connection Timeout (ms)Wait time for connection establishment5000Default 5000; negative values are not accepted
IO ThreadsHTTP client thread count32Minimum 1; should be increased for high traffic
Max Connection Per HostConcurrent request limit per host128Minimum 1
Max Connection TotalTotal connection pool limit256Minimum 1
Connection TypeREAD_WRITE or READ modeREAD_WRITEIf READ is selected, administrate is disabled

Optional Parameters

ParameterDescriptionDefault ValueRecommended Value
DescriptionConnection purpose descriptionEmptyShort text containing operational information
AuthenticateBasic Authentication on/offfalsetrue based on requirements in Production
Elastic UsernameUsernameEmptyRequired if Authentication is active
Elastic PasswordPasswordEmptyShould be entered through secret manager
AdministrateTemplate/ILM managementtrue (READ_WRITE)Can be closed if external team manages
Socket Keep AliveTCP keep-alivetrueKeep enabled if network devices drop idle connections
Socket Reuse AddressAddress reusetrueKeep enabled in multi-worker deployments
Disable Hostname VerificationTLS hostname verificationtrueChange to false in Production

Timeout and Connection Pool Parameters

ParameterDescriptionDefaultMinMaxUnit
Connection TimeoutMaximum wait time for connection establishment5000100060000milliseconds
Request TimeoutWait time for Elasticsearch response600001000120000milliseconds
Pool SizeMaximum number of connections in the connection pool25612000count
Socket Idle TimeoutTimeout for closing idle connections300001000600000milliseconds

Usage Scenarios

ScenarioSituationSolution (Connection Configuration)Expected Behavior / Result
High-Volume Log WritingMillions of log entries per minuteREAD_WRITE, administrate enabled, ioThreads=64, maxConnectionTotal=512ILM automatically performs rollover, no write queue forms
Reporting ClusterRead-only queriesREAD, administrate disabled, authentication=trueCluster only receives queries, management operations are blocked
Multiple Host FailoverTwo data centersTwo HTTPS hosts, encrypt communication + PKCS#12 CATraffic automatically routes to healthy host
Schema UpdateNew fields addedUpdate template name and shard/replica, then run “Create Index Template”New indices open with current schema
Data Retention PolicyLogs older than 90 days will be deletedILM delete phase active, minAgeOfDelete=90Old indices are automatically cleaned
Secure TunnelTLS required, internal CAEncrypt communication enabled, CA_IN_PEM_FILE uploadedSecure 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

Image 2024 9 9 15 35 35 Pn

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.
Name (Name) - Required Field:
  • 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
Description (Description) - Optional:
  • 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.
Host/Port - Required:
  • 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.
Connection Type Selection:
  • 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.
Administrate Setting:
  • 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
ILM Policy Configuration:
  • 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
IO Threads:
  • Enter the HTTP client thread count in the IO Threads field.
  • Minimum: 1
  • Should be increased for high traffic (e.g., 64)
Max Connection Per Host:
  • Enter the concurrent request limit per host in the Max Connection Per Host field.
  • Minimum: 1
  • Recommended: 128
Max Connection Total:
  • Enter the total connection pool limit in the Max Connection Total field.
  • Minimum: 1, Maximum: 2000
  • Recommended: 256
Socket Settings:
  • 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.
Username and Password:
  • 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.
Encrypt Communication (TLS):
  • 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.
Disable Hostname Verification:
  • 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
Checklist (Before Saving):
  • 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
Result:
  • 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 / StepDescription and Functions
Delete OperationSelect Delete from the menu at the end of the row or click the [Delete] button on the connection detail page
Delete TipsCheck 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: DeactivateInstead 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 / StepDescription and Functions
ExportMethod 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 FormatFormat: Date-connection-ConnectionName-export.zip. Example: `13 Nov 2025-connection-Production_ElasticLog-export.zip`
ZIP ContentsConnection JSON file, Metadata information, Dependency information (e.g., certificates, key store)
Usage AreasBackup, Moving between environments (Test → Prod), Versioning, Team or project-based sharing
ImportClick 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 ScenariosScenario 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 LocationDescription and Functions
Connection Creation and ActivationSteps: 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 StepsConnection 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 UsageIn 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 UsageConnection 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

CategoryDescription / Recommendations
Index NamingBad: index1. Good: log-prod. Best: `prod-apiproxy-log-{yyyy.MM.dd}`
ILM PoliciesBad: 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 ManagementBad: Sharing the same certificate across all environments. Good: Loading environment-based certificates. Best: Planning certificate rotation with automation and setting expiration alarms
Connection Type SelectionBad: Giving READ_WRITE to read-only cluster. Good: Making selection according to permission requirements. Best: Updating connection type if cluster role changes
Environment ManagementBad: 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 TestBad: 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 AreaDescription / Warnings
Access SegmentationCreate separate connections and RBAC users for production cluster; do not share access tokens
File UploadsDo not put PKCS#12/PEM files in version control; upload through secret storage
Hostname VerificationDisable Hostname Verification should only be used for testing; recommended to leave as false in production
Credential ManagementStore 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 UsageAlways enable SSL/TLS in production environment. Use self-signed certificates only in development environment. Track certificate expiration dates and renew them on time
Access ControlAllow only authorized users to change connection configuration. Store connection change logs. Apply change approval process for critical connections

Things to Avoid

CategoryDescription / Warnings
Index Name ReuseWhy to avoid: Creates conflicts in indices sharing the same template. Alternative: Use project-based prefix
Missing Host DefinitionWhy to avoid: All flows stop if single host fails. Alternative: Enter at least two hosts, monitor health check
Unallowed TLS TypesWhy to avoid: Wrong file type leads to handshake failure. Alternative: Use certificate package appropriate for HTTPS selection
Using Production Connection in Test EnvironmentWhy 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 ValuesWhy 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 PoolWhy 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

CriterionRecommendation / Effect
Shard/Replica PlanningRecommendation: 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 DurationsRecommendation: Reduce storage costs by keeping hot phase short and cold phase long. Effect: Unnecessary data is not kept on expensive nodes
Thread Pool MonitoringRecommendation: 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 OptimizationRecommendation: 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 OptimizationRecommendation: 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 MonitoringRecommendation: 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

ProblemPossible CausesSolution Steps
Index Template Not CreatedAdministrate disabled, Template name conflicts, Elasticsearch user permission insufficient1. Enable Administrate. 2. Change template name. 3. Grant manage_index_templates permission to user
ILM Policy Not SavingPolicy name exists, Hot phase disabled, UI modal not closed1. Make policy name unique. 2. Enable Hot phase. 3. Click Save in modal and try again
Connection TimeoutNetwork delay, Target system responding slowly, Timeout value too low1. Check network connectivity. 2. Check target system health. 3. Increase timeout values. 4. Review connection logs
Authentication FailedWrong username/password, Expired credentials, Permission problem1. Verify credentials. 2. Check that user is active in target system. 3. Check that necessary permissions are granted. 4. Check SSL/TLS certificates
Pool ExhaustedPool size too low, Connection leak exists, Traffic too high1. 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 ErrorsDifferent connection may be selected in Integration/Connector step, Step may be misconfigured, Flow/Job may not be redeployed1. 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)

CategoryQuestion (Q)Answer (A)
GeneralCan 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
GeneralWhat does the Rollover button do?Manually rollovers the active index of the specified connection; can be used in emergencies before ILM threshold is reached
TechnicalCan 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
TechnicalDoes 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
UsageWhat 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
GeneralCan 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
TechnicalIs 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
UsageShould 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
TechnicalTest 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